CSS plays a very important role in a web page. With the development of CSS in recent years, pseudo-elements/pseudo-classes have also begun to be widely used: at a time when performance is becoming more and more important, CSS pseudo-elements/pseudo-classes outside the document flow are the well-deserved "uncrowned kings"! Here are some of the "sexy operations" about CSS summarized by the author, I hope it can be helpful to you: :hover and :focus display floating layer We can completely use only CSS parent-child selector (for "parent-child nesting")/sibling selector (for "parallel arrangement of the same level") + pseudo-class <a href="javascript:;">Image link</a> <img src="xxx" alt="" /> img{ visibility: hidden; position: absolute; transition: visibility .2s; /** Set delay **/ } a:hover + img, img:hover{ visibility: visible; } Finally, But this will "fail" in one situation: no mouse environment. For example: mobile terminals and smart devices. We can add the pseudo class a:focus + img, img:focus{ visibility: visible; transition: none; } :focus:hover In fact, in the drop-down list. I don’t recommend using “parallel elements without parent-child relationships” — if you’re just using CSS. The problem lies in focus: <div class="y-table"> <a href="javascript:;" class="y-msg">My Message</a> <div class="cs-list"> <a href="javascript:;">My Answer</a> <a href="javascript:;">My private message</a> <a href="javascript:;">My Orders</a> <a href="javascript:;">My Follow</a> <a href="javascript:;">My Favorites</a> </div> </div> :focus-within :not() determines the display element In the [Search] button on a web page, there is a scenario where a list is displayed based on the entered keywords. The author once wrote an article using JavaScript to illustrate the scenario: (JavaScript) How does the instant auto-completion function of Baidu/Google search "work"? In fact, we can also use CSS .list:not([class="show"]) { display: none; } In CSS3 selectors, there is something called attribute selector, which has the following usages: Then, when filtering, dynamically add the show class name to some items in the returned list based on whether they meet the conditions. We can even use "custom data attributes": :not Click the button to display the chrysanthemum picture Let’s talk about a common usage scenario: in a form, when you click the submit button, if users can see “more feedback effects”, it seems that the web page will be more popular. So, it seems like a good idea to let the user know that they are waiting when you "submit the form": Control the class name through JavaScript, add loading-name to the button when clicked, make its text transparent, and set the background to a loading image! When you see "click", I think you should think of "pseudo-class: focus" or "pseudo-class: active" for a moment, try to rewrite it! :active implements "data reporting" In fact, there is a small problem in the web page: what if the user disables JavaScript/the browser does not support JavaScript? Of course, the latter situation basically does not occur now, but it is indeed a thorny problem and has attracted a large number of front-end developers to devote their efforts to it! This issue has been mentioned in other articles of the author. Here we will only talk about "data reporting": If there is no form and JavaScript is not supported (ajax cannot be used), how to pass data to the backend? Fortunately, there is the pseudo-class We usually use active and after together: Even if you don’t believe it, it does send a request to the server and upload the data! Why use url here? If you do not use the image format, you can only write fixed values in the string format of after-content. ::after and ::before scenarios As the "leaders" among pseudo-elements/pseudo-classes, how can we not talk about after and before? They are used in so many scenarios: they can be seen in the common "'|' symbol between words", "horizontal lines before and after words", "some special patterns and even combined patterns": A "search icon" style implementation A cool "loading" implemented in pure CSS This is the end of this article about the wonderful uses of CSS pseudo-elements and pseudo-classes. For more relevant CSS pseudo-elements and pseudo-classes, please search for previous articles on 123WORDPRESS.COM or continue to browse the related articles below. I hope that everyone will support 123WORDPRESS.COM in the future! |
<<: Some CSS questions you may be asked during an interview
>>: How to get the contents of .txt file through FileReader in JS
Docker container connection 1. Network port mappi...
Today I will introduce to you a difference betwee...
1. Command Introduction bzip2 is used to compress...
1. Unzip MySQL 8.0.16 The dada folder and my.ini ...
This article shares the MySQL 5.7.18 MSI installa...
What is MIME TYPE? 1. First, we need to understand...
1. Permanent modification, valid for all users # ...
Table of contents Overview What is Big O notation...
Preface When you install MySQL, you usually creat...
React Native is a cross-platform mobile applicati...
MySQL is the most popular relational database man...
Table of contents 1. Database design 2. Front-end...
1. Download from the official website and unzip h...
Table of contents Preface 1. Tomcat class loader ...
This article uses an example to describe how to c...