Skip to main content

Project Study: Five Advanced CSS Selectors You Should Know

Today, I am going to share five advanced CSS selectors from Udemy course. Then, I will create a simple project to explain how we apply each selectors.

Those five advanced selectors are:
  • Star Selector: Whatever we do, it will apply to every single element.
  • Descendant Selector: The way that descendant selector works is that it takes two or more tag names or two or more selectors and you chain them together.
  • Adjacent Selector: With adjacent selector, it will let us select elements that comes after another element.
  • Attribute Selector: The attribute selector is a way to select elements based of any attribute.
  • Nth of Type: The way of nth of type works is it takes a number like three or five and then it selects every end of a specific element. So if I want to select every fifth paragraph, I could use nth of type.

I know it is not clear to understand without apply them in a project and see how they work.

Now I am going to create a simple web page named "Selector Demo", which includes some lists and hyperlinks.

The HTML Part:


The Web page looks like:

Now I am going to apply those five selectors in the CSS file.


  • Star Selector
I want every element on the page has a border, so the simple way is to use star selector:
*{border: 1px solid lightgrey:}
  • Descendant Selector
As we can see, there are three hyperlinks on the last list, and I want to make those links text in red color, so I use descendant selector:
li a{ color: red:}.
  • Adjacent Selector
There are two h4 headers, one is "Popular Vegetables", and the other one is "Popular Sites". Under each header, there is a short list. I want to add a blue border to each list. Therefore, I use adjacent selector: 
h4+ul { border: 4px solid blue;}.
  • Attribute Selector
There are four hyperlinks on this page, and two of them are linking to Google. I want to give a yellow background to Google links. As we know, the hyperlink attribute is " a href=", so the attribute selector will be 
a[href="http://www.google.com"] { background: yellow;}
  • Nth of Type
I build three lists on the page. I want the even number on every list has a green background, so I use the nth of type: 
li:nth-of-type(even) { background: green;}

The final outcome will be:



Comments

Popular posts from this blog

Intermediate Express.js: How To Add Styles & Partials in EJS File?

So far, we only have simple HTML tags and ejs tags in each ejs file. Every template page has no style at all. And the basic HTML header and footer are also missing. Today, I learned how to add styles and partials in ejs file. Link Style Step One: Touch a Separate CSS file I create a new directory "Style" under the "EJSDemo" directory, then I add a new CSS file "app.css" inside "Style" folder. Step Two: Add app.use(express.static()) in the app.js I add app.use(express.static("style")) in the "app.js". This will tell Express.js to serve the content of "Style" directory. Step Three: Write styles in CSS file I simple give body an orange background color and set text color to be grey. Step Four: Link to CSS file in the EJS file I just add <link> tag to link the "app.css" file on the top of the h1 tag in each ejs template. As the result, when I run the app and...

My Story: A Mommy Start To Learn Code From Zero

From Google Image I am not a programmer, and I thought I would never become one. Everytime I see someone is coding, I think he or she must be very talent.  For me, coding is a very difficult subject to learn. Not only the language has so many rules, but also the logical reasoning behind the language is complex.  In my graduated school, I knew many friends who didn't have any coding background, but they are doing programmer or developer jobs now. Some of them went to school to study coding, and some of them  learned to code by themselves. Their stories are so impressive.  I wasn't ready to learn code until I finished my first Chinese book "留学,我的青春呀!" recently. I always want to be a writer and write my own book. I started writing blog three years ago, and I updated my post two to three times every week. As I enjoyed writing , I started to get some followers, likes, and good comments on my blog. Then, I decided to plan my first book. My First...

Three Most Common HTML Form Elements You Should Know

When I visited the Facebook page at the first time, it required me to sign up. Therefore, I completed the sign up form to create my new account. The form is very simple to fill in because it only asks for very common information such as full name, phone number, new password, birthday, and gender. It only took me one or two minutes to finish the form. Not only Social media sites require us to sign up first before we post anything, but many business or eCommerce sites also ask us to create new account before we take any action. For example, when I go to the Origins skin care site, it will pop up a email sign up form window. To encourage new customers to sign up, it gives a 15% off for the first order. It is definitely an attractive call-to-action message. Anyway, if your website requires users to sign up, you need to know how to create a HTML form. Yesterday, I just learned how to build a simple HTML form from Udemy course. And it is not that hard. All you need to kno...