Pseudo-classes and pseudo-elements - Learn web development 编辑

The next set of selectors we will look at are referred to as pseudo-classes and pseudo-elements. There are a large number of these, and they often serve quite specific purposes. Once you know how to use them, you can look at the list to see if there is something which works for the task you are trying to achieve. Once again the relevant MDN page for each selector is helpful in explaining browser support.

Prerequisites:Basic computer literacy, basic software installed, basic knowledge of working with files, HTML basics (study Introduction to HTML), and an idea of how CSS works (study CSS first steps.)
Objective:To learn about the pseudo-class and pseudo-element selectors.

What is a pseudo-class?

A pseudo-class is a selector that selects elements that are in a specific state, e.g. they are the first element of their type, or they are being hovered over by the mouse pointer. They tend to act as if you had applied a class to some part of your document, often helping you cut down on excess classes in your markup, and giving you more flexible, maintainable code.

Pseudo-classes are keywords that start with a colon:

:pseudo-class-name

Simple pseudo-class example

Let's look at a simple example. If we wanted to make the first paragraph in an article larger and bold, we could add a class to that paragraph and then add CSS to that class, as shown in the first example below:

However, this could be annoying to maintain — what if a new paragraph got added to the top of the document? We'd need to move the class over to the new paragraph. Instead of adding the class, we could use the :first-child pseudo-class selector — this will always target the first child element in the article, and we will no longer need to edit the HTML (this may not always be possible anyway, maybe due to it being generated by a CMS.)

All pseudo-classes behave in this same kind of way. They target some bit of your document that is in a certain state, behaving as if you had added a class into your HTML. Take a look at some other examples on MDN:

Note: It is valid to write pseudo-classes and elements without any element selector preceding them. In the example above, you could write :first-child and the rule would apply to any element that is the first child of an <article> element, not just a paragraph first child — :first-child is equivalent to *:first-child. However, usually you want more control than that, so you need to be more specific.

User-action pseudo classes

Some pseudo-classes only apply when the user interacts with the document in some way. These user-action pseudo-classes, sometimes referred to as dynamic pseudo-classes, act as if a class had been added to the element when the user interacts with it. Examples include:

  • :hover — mentioned above; this only applies if the user moves their pointer over an element, typically a link.
  • :focus — only applies if the user focuses the element using keyboard controls.

What is a pseudo-element?

Pseudo-elements behave in a similar way, however they act as if you had added a whole new HTML element into the markup, rather than applying a class to existing elements. Pseudo-elements start with a double colon ::.

::pseudo-element-name

Note: Some early pseudo-elements used the single colon syntax, so you may sometimes see this in code or examples. Modern browsers support the early pseudo-elements with single- or double-colon syntax for backwards compatibility.

For example, if you wanted to select the first line of a paragraph you could wrap it in a <span> element and use an element selector; however, that would fail if the number of words you had wrapped were longer or shorter than the parent element's width. As we tend not to know how many words will fit on a line — as that will change if the screen width or font-size changes — it is impossible to robustly do this by adding HTML.

The ::first-line pseudo-element selector will do this for you reliably — if the number of words increases and decreases it will still only select the first line.

It acts as if a <span> was magically wrapped around that first formatted line, and updated each time the line length changed.

You can see that this selects the first line of both paragraphs.

Combining pseudo-classes and pseudo-elements

If you wanted to make the first line of the first paragraph bold you could chain the :first-child and ::first-line selectors together. Try editing the previous live example so it uses the following CSS. We are saying that we want to select the first line, of the first <p> element, which is inside an <article> element.

article p:first-child::first-line {
  font-size: 120%;
  font-weight: bold;
}

Generating content with ::before and ::after

There are a couple of special pseudo-elements, which are used along with the content property to insert content into your document using CSS.

You could use these to insert a string of text, such as in the live example below. Try changing the text value of the content property and see it change in the output. You could also change the ::before pseudo-element to ::after and see the text inserted at the end of the element instead of the beginning.

Inserting strings of text from CSS isn't really something we do very often on the web however, as that text is inaccessible to some screen readers and might be hard for someone to find and edit in the future.

A more valid use of these pseudo-elements is to insert an icon, for example the little arrow added in the example below, which is a visual indicator that we wouldn't want read out by a screenreader:

These pseudo-elements are also frequently used to insert an empty string, which can then be styled just like any element on the page.

In this next example, we have added an empty string using the ::before pseudo-element. We have set this to display: block in order that we can style it with a width and height. We then use CSS to style it just like any element. You can play around with the CSS and change how it looks and behaves.

The use of the ::before and ::after pseudo-elements along with the content property is referred to as "Generated Content" in CSS, and you will often see this technique being used for various tasks. A great example is the site CSS Arrow Please, which helps you to generate an arrow with CSS. Look at the CSS as you create your arrow and you will see the ::before and ::after pseudo-elements in use. Whenever you see these selectors, look at the content property to see what is being added to the document.

Reference section

There are a large number of pseudo-classes and pseudo-elements, and it is useful to have a list to refer to. Below are tables listing them, with links to their reference pages on MDN. Use this as a reference to see the kind of things that are available for you to target.

Pseudo-classes

SelectorDescription
:activeMatches when the user activates (for example clicks on) an element.
:any-linkMatches both the :link and :visited states of a link.
:blankMatches an <input> element whose input value is empty.
:checkedMatches a radio button or checkbox in the selected state.
:currentMatches the element, or an ancestor of the element, that is currently being displayed.
:defaultMatches the one or more UI elements that are the default among a set of similar elements.
:dirSelect an element based on its directionality (value of the HTML dir attribute or CSS direction property).
:disabledMatches user interface elements that are in an disabled state.
:emptyMatches an element that has no children except optionally white space.
:enabledMatches user interface elements that are in an enabled state.
:firstIn Paged Media, matches the first page.
:first-childMatches an element that is first among its siblings.
:first-of-typeMatches an element which is first of a certain type among its siblings.
:focusMatches when an element has focus.
:focus-visibleMatches when an element has focus and the focus should be visible to the user.
:focus-withinMatches an element with focus plus an element with a descendent that has focus.
:futureMatches the elements after the current element.
:hoverMatches when the user hovers over an element.
:indeterminateMatches UI elements whose value is in an indeterminate state, usually checkboxes.
:in-rangeMatches an element with a range when its value is in-range.
:invalidMatches an element, such as an <input>, in an invalid state.
:langMatches an element based on language (value of the HTML lang attribute).
:last-childMatches an element which is last among its siblings.
:last-of-typeMatches an element of a certain type that is last among its siblings.
:leftIn Paged Media, matches left-hand pages.
:linkMatches unvisited links.
:local-linkMatches links pointing to pages that are in the same site as the current document.
:is()Matches any of the selectors in the selector list that is passed in.
:notMatches things not matched by selectors that are passed in as a value to this selector.
:nth-childMatches elements from a list of siblings — the siblings are matched by a formula of the form an+b (e.g. 2n + 1 would match elements 1, 3, 5, 7, etc. All the odd ones.)
:nth-of-typeMatches elements from a list of siblings that are of a certain type (e.g. <p> elements) — the siblings are matched by a formula of the form an+b (e.g. 2n + 1 would match that type of element, numbers 1, 3, 5, 7, etc. All the odd ones.)
:nth-last-childMatches elements from a list of siblings, counting backwards from the end. The siblings are matched by a formula of the form an+b (e.g. 2n + 1 would match the last element in the sequence, then two elements before that, then two elements before that, etc. All the odd ones, counting from the end.)
:nth-last-of-typeMatches elements from a list of siblings that are of a certain type (e.g. <p> elements), counting backwards from the end. The siblings are matched by a formula of the form an+b (e.g. 2n + 1 would match the last element of that type in the sequence, then two elements before that, then two elements before that, etc. All the odd ones, counting from the end.)
:only-childMatches an element that has no siblings.
:only-of-typeMatches an element that is the only one of its type among its siblings.
:optionalMatches form elements that are not required.
:out-of-rangeMatches an element with a range when its value is out of range.
:pastMatches the elements before the current element.
:placeholder-shownMatches an input element that is showing placeholder text.
:playingMatches an element representing an audio, video, or similar resource that is capable of being “played” or “paused”, when that element is “playing”.
:pausedMatches an element representing an audio, video, or similar resource that is capable of being “played” or “paused”, when that element is “paused”.
:read-onlyMatches an element if it is not user-alterable.
:read-writeMatches an element if it is user-alterable.
:requiredMatches form elements that are required.
:rightIn Paged Media, matches right-hand pages.
:rootMatches an element that is the root of the document.
:scopeMatches any element that is a scope element.
:validMatches an element such as an <input> element, in a valid state.
:targetMatches an element if it is the target of the current URL (i.e. if it has an ID matching the current URL fragment).
:visitedMatches visited links.

Pseudo-elements

SelectorDescription
::afterMatches a stylable element appearing after the originating element's actual content.
::beforeMatches a stylable element appearing before the originating element's actual content.
::first-letterMatches the first letter of the element.
::first-lineMatches the first line of the containing element.
::grammar-errorMatches a portion of the document containing a grammar error as flagged by the browser.
::markerMatches the marker box of a list item, which typically contains a bullet or number.
::selectionMatches the portion of the document that has been selected.
::spelling-errorMatches a portion of the document containing a spelling error as flagged by the browser.

In this module

  1. Cascade and inheritance
  2. CSS selectors
  3. The box model
  4. Backgrounds and borders
  5. Handling different text directions
  6. Overflowing content
  7. Values and units
  8. Sizing items in CSS
  9. Images, media, and form elements
  10. Styling tables
  11. Debugging CSS
  12. Organizing your CSS

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

词条统计

浏览:144 次

字数:26160

最后编辑:7 年前

编辑次数:0 次

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文