Jump to content

Recommended Posts

Posted

CSS - Cascading Style Sheets

 

css.png

 


 

What You Should Already Know!

 

Before you continue you should have a basic understanding of the following:

 

  • HTML / XHTML

 


 

What Is CSS;

 

  • CSS stands for Cascading Style Sheets
  • Styles define how to display HTML elements
  • Styles were added to HTML 4.0 to solve a problem
  • External Style Sheets can save a lot of work
  • External Style Sheets are stored in CSS files

 

Styles Solved a Big Problem!

 

HTML was never intended to contain tags for formatting a document.

 

HTML was intended to define the content of a document, like:

 

<h1>This is a heading</h1>

 

<p>This is a paragraph.</p>

 

When tags like <font>, and color attributes were added to the HTML 3.2 specification, it started a nightmare for web developers. Development of large web sites, where fonts and color information were added to every single page, became a long and expensive process.

 

To solve this problem, the World Wide Web Consortium (W3C) created CSS.

 

In HTML 4.0, all formatting could be removed from the HTML document, and stored in a separate CSS file.

 

All browsers support CSS today.

 

CSS Saves a Lot of Work!

 

CSS defines HOW HTML elements are to be displayed.

 

Styles are normally saved in external .css files. External style sheets enable you to change the appearance and layout of all the pages in a Web site, just by editing one single file!

 


 

CSS Syntax!

 

A CSS rule has two main parts: a selector, and one or more declarations:

 

selector.gif

 

The selector is normally the HTML element you want to style.

 

Each declaration consists of a property and a value.

 

The property is the style attribute you want to change. Each property has a value.

 


 

CSS Example!

 

A CSS declaration always ends with a semicolon, and declaration groups are surrounded by curly brackets:

 

p {color:red;text-align:center;}

 

To make the CSS more readable, you can put one declaration on each line, like this:

 

p
{
color:red;
text-align:center;
}

 


 

CSS Comments!

 

Comments are used to explain your code, and may help you when you edit the source code at a later date. Comments are ignored by browsers.

 

A CSS comment begins with "/*", and ends with "*/", like this:

 

/*This is a comment*/
p
{
text-align:center;
/*This is another comment*/
color:black;
font-family:arial;
}

 


 

The id and class Selectors!

 

In addition to setting a style for a HTML element, CSS allows you to specify your own selectors called "id" and "class".

 

The id Selector.

 

The id selector is used to specify a style for a single, unique element.

 

The id selector uses the id attribute of the HTML element, and is defined with a "#".

 

The style rule below will be applied to the element with id="para1":

 

#para1
{
text-align:center;
color:red;
}

 

Do NOT start an ID name with a number! It will not work in Mozilla/Firefox.

 

The class Selector.

 

The class selector is used to specify a style for a group of elements. Unlike the id selector, the class selector is most often used on several elements.

 

This allows you to set a particular style for many HTML elements with the same class.

 

The class selector uses the HTML class attribute, and is defined with a "."

 

In the example below, all HTML elements with class="center" will be center-aligned:

 

.center {text-align:center;}

 

You can also specify that only specific HTML elements should be affected by a class.

 

In the example below, all p elements with class="center" will be center-aligned:

 

p.center {text-align:center;}

 

Do NOT start a class name with a number! This is only supported in Internet Explorer.

 


 

Three Ways to Insert CSS.

 

There are three ways of inserting a style sheet:

 

  • External style sheet
  • Internal style sheet
  • Inline style

 

External Style Sheet.

 

An external style sheet is ideal when the style is applied to many pages. With an external style sheet, you can change the look of an entire Web site by changing one file. Each page must link to the style sheet using the <link> tag. The <link> tag goes inside the head section:

 

<head>
<link rel="stylesheet" type="text/css" href="mystyle.css" />
</head>

 

An external style sheet can be written in any text editor. The file should not contain any html tags. Your style sheet should be saved with a .css extension. An example of a style sheet file is shown below:

 

hr {color:sienna;}
p {margin-left:20px;}
body {background-image:url("images/back40.gif");}

 

Do not leave spaces between the property value and the unit (such as margin-left:20 px). Correct way: margin-left:20px.

 

Internal Style Sheet.

 

An internal style sheet should be used when a single document has a unique style. You define internal styles in the head section of an HTML page, by using the <style> tag, like this:

 

<head>
<style type="text/css">
hr {color:sienna;}
p {margin-left:20px;}
body {background-image:url("images/back40.gif");}
</style>
</head>

 

Inline Styles.

 

An inline style loses many of the advantages of style sheets by mixing content with presentation. Use this method sparingly!

 

To use inline styles you use the style attribute in the relevant tag. The style attribute can contain any CSS property. The example shows how to change the color and the left margin of a paragraph:

 

<p style="color:sienna;margin-left:20px">This is a paragraph.</p>

 

Multiple Style Sheets.

 

If some properties have been set for the same selector in different style sheets, the values will be inherited from the more specific style sheet.

 

For example, an external style sheet has these properties for the h3 selector:

 

h3
{
color:red;
text-align:left;
font-size:8pt;
}

 

And an internal style sheet has these properties for the h3 selector:

 

h3
{
text-align:right;
font-size:20pt;
}

 

If the page with the internal style sheet also links to the external style sheet the properties for h3 will be:

 

color:red;
text-align:right;
font-size:20pt;

 

The color is inherited from the external style sheet and the text-alignment and the font-size is replaced by the internal style sheet.

 

Multiple Styles Will Cascade into One.

 

Styles can be specified:

 

  • inside an HTML element
  • inside the head section of an HTML page
  • in an external CSS file
  • Tip: Even multiple external style sheets can be referenced inside a single HTML document.

 

Cascading order

 

What style will be used when there is more than one style specified for an HTML element?

 

Generally speaking we can say that all the styles will "cascade" into a new "virtual" style sheet by the following rules, where number four has the highest priority:

 

  • Browser default
  • External style sheet
  • Internal style sheet (in the head section)
  • Inline style (inside an HTML element)

 

So, an inline style (inside an HTML element) has the highest priority, which means that it will override a style defined inside the <head> tag, or in an external style sheet, or in a browser (a default value).

 

Note: If the link to the external style sheet is placed after the internal style sheet in HTML <head>, the external style sheet will override the internal style sheet!

 


 

CSS Tutorial via Video Version:

 

 

 


 

Have Fun, and good practice!

 

 

 

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now


  • Posts

    • I'm using Myext64 HF and recently tried to replicate the "br_xmas09_event" Raising Rudolph Event. Detailed event information can be found at https://legacy-lineage2.com/news/_rudolf_the_red.html After configuring .eventdata.xml and starting the server, t  server log shows: 12/02/2025 15:39:01.809, [NO_ERROR] SpawnEx2 [br_xmas2009_invisible][schuttgart20_npc2213_xs03m1] [1][0][0][0][0][346796390] 12/02/2025 15:39:02.057, DummyPacket received from L2Server 12/02/2025 15:39:02.058, server socket close 312ac(f0820224) error(997) 12/02/2025 15:39:02.058, [CallStack][tid:0][tick:2][0] Begin 12/02/2025 15:39:02.058, [CallStack][tid:0][tick:2][1][0] void __cdecl IOThreadCallback::IOThread_common(void) 12/02/2025 15:39:02.059, [CallStack][tid:0][tick:2][2][1] void IOThread_common 1 12/02/2025 15:39:02.059, [CallStack][tid:0][tick:2][3][2] void __cdecl CIOSocketEx<class CIOBufferEx<16384> >::Close(void) 12/02/2025 15:39:02.059, [CallStack][tid:0][tick:2][4][3] void __cdecl CServerSocket::OnClose(void) 12/02/2025 15:39:02.059, [CallStack][tid:0][tick:2][5] End l2server log: 12/02/2025 15:39:02.112, npc server closed(127.0.0.1) error: 64 read buffer size: (server:0 npc:0) 12/02/2025 15:39:02.112, [NO_ERROR] L2Server is under protection mode!!! 12/02/2025 15:39:02.112, [NO_ERROR] L2Server is under protection mode!!! 12/02/2025 15:39:02.112, [NO_ERROR] L2Server is under protection mode!!! 12/02/2025 15:39:02.131, dwTime[0] < 80 !!!!!!! 12/02/2025 15:39:02.131, [CallStack][tid:7][tick:1][0] Begin 12/02/2025 15:39:02.132, [CallStack][tid:7][tick:1][1][0] void __cdecl IOThreadCallback::IOThread_common(void) 12/02/2025 15:39:02.132, [CallStack][tid:7][tick:1][2][1] void IOThread_common 1 12/02/2025 15:39:02.132, [CallStack][tid:7][tick:1][4][3] void __cdecl NpcSocket::OnClose(void) 12/02/2025 15:39:02.132, [CallStack][tid:7][tick:1][3][2] void __cdecl CIOSocketEx<class CIOBufferEx<16384> >::Close(void) 12/02/2025 15:39:02.132, [CallStack][tid:7][tick:1][5] End 12/02/2025 15:39:31.767, server closed(127.0.0.1) Error: 64 Read buffer size: (server:0 npc:0) 12/02/2025 15:39:31.768, [NO_ERROR] Logout All Characters : 1   The NPC server sent a packet to the L2 server while generating the br_xmas2009_invisible game NPC server, and the NPC server subsequently crashed.     After some digging, I found a clue in a very old MXC post, but the fix was for the GF version. The whole problem is in l2server side support for NPC function CreateOnePrivateNearUser. It sends CreatePacket but Koreans made some changes in it (added instance ID) so it got broken. As Santa event is the only AI that uses this function, they probably don't know about it    So is there a way to fix this problem, specifically for Myext64 HF? I'd be happy to buy him coffee.
    • Offtopic, personal attacks, probably too old to use that much memes and what's YOUR actual contribution to L2J, in order I laugh aswell ?   The main poster quotes my pack so I answer accordingly, while you advertise L2JFrozen in both of your posts - discontinued since 2014 (? 1132 rev), with none taking back the open source lead while anyone could.   If you're somewhat affiliated to hopzone, you probably packed way more money than me. Packs don't make any type of money (barely 100e/month) and if you would follow me, you would know there are ways to handle it or even getting paid.   Hope I was short enough, 🧂🤡.
    • Hi guys, this is a CMS im sharing for lineage 2 servers, im tired of the crap i see on new release servers. Dont let me start on the IA developed ones lmao.   📋 Description Free and open source template to create landing pages for Lineage 2 private servers. Designed with a dark fantasy theme and modern animations. ✨ Current Features This FREE version includes: Complete Landing Page - Professional design ready to use Multi-language Support - Spanish, English, Portuguese Dark Fantasy Theme - With animated UI elements Server Information - Rates, features, and rules Olympiad Ranking - Rankings display Download Section - For game client Skins and Animations Gallery Streaming Widget - Twitch/Kick integration Fully Customizable - Via configuration files ❌ Not Included in Free Version ❌ User Registration System ❌ Online Players Counter ❌ Donation Panel 💎 Premium Integrations IntegrationPrice Registration System $50 USD Online Players Counter $50 USD Donation Panel $50 USD   📧 Contact: https://gh0tstudio.com 🛠️ Tech Stack Technology    Version    Description React              19.2.0       UI Library TypeScript       5.8.2        Static typing Vite                 6.2.0         Build tool TailwindCSS   CDNCSS    Framework Lucide React   0.554.0         Icons i18next           23.16.0       Internationalization react-i18next   15.1.0        React bindings for i18n All documentation provided for AI AGENTS to make changes on the ui texts and so on. u can have a look on the cms fully working with donation panel, online count and register via: https://crmlineage2.vercel.app/ https://github.com/6h0T/CRM-LINEAGE2-FREE If u are in the lookings to develop a unique website for ur projects, u can dm me or contact me throw my socials on my profile. all code has encrypted references so any type of rebranding, copying or selling without authorization will result in take downs
    • Hello dude, i can help u out, i reached to u via DM, my studio is https://gh0tstudio.com i have worked with almost 40 brands on developing Private Lineage and Mu online servers, dashboard for vote pages and more. I sent u some examples too
    • L2 TARTARUS - HTML DESIGN       L2 KOMBAT - ANIMATED BORDER   L2 SERENITY - ANIMATED LOGO   L2 ARCANE - COMMUNITY BOARD     L2 AMERIKA - ADVERTISING BANNER   L2 ZERON - ADVERTISING BANNER  
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock