国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Table of Contents
1. The mouse slides over to trigger the selected state
將軍,夫人喊你種田了
被奪一切后她封神回歸
四、默認(rèn)列表的第一項為選中態(tài)
五、總結(jié)一下
Home Web Front-end CSS Tutorial CSS tip: Use transition to retain hover state

CSS tip: Use transition to retain hover state

Sep 27, 2022 pm 02:01 PM
css hover transition

How to retain the hover state? The following article will introduce to you how to retain the hover state without using JavaScript. I hope it will be helpful to you!

CSS tip: Use transition to retain hover state

Normally, hover cannot save the state. Additional styles are triggered when the mouse is moved in, and restored once the mouse is moved out.

el:hover{
??color:?red
}

This means that if you need to retain the status of hover, you may have to resort to JS. For example, the following is the ranking effect of the home page of a certain academy

Kapture 2022-09-26 at 18.37.28

The main interactions here are as follows

  • The mouse slides over to trigger the selected state

  • The last selected state will remain after the mouse is moved out of the list (emphasis added)

  • The first item in the default list is selected

The current implementation of the official website is also implemented through JS. In fact, it can be completely achieved only through CSS, and some small delays of transition are required. Let’s take a look at the techniques. [Recommended learning: css video tutorial]

1. The mouse slides over to trigger the selected state

Everything is inseparable from layout.

Assume the listHTML is like this


    ????
  • ??????

    將軍,夫人喊你種田了

    ??????

    只是在休息室里打了個盹兒,一睜眼,竟然穿成了古代目不識丁的鄉(xiāng)下胖丫頭。?好吃懶做不說,還在村里橫行霸道。?十里八鄉(xiāng)沒人愿意娶她,好不容易買了個金龜婿,大婚之日竟讓人逃了。?惡霸老爹一怒之下去道上擄了個夫君給她。?就是……爹你擄的是不是有點不太對呀??*?婚后的蘇胖丫很忙。?忙著改造惡霸爹爹與惡霸弟弟。?忙著搶救貌美如花的神將夫君。?忙著養(yǎng)育三個小小惡霸小豆丁。?一不小心,將自己忙成了大燕最位高權(quán)重的一品女侯!

    ????
  • ??
  • ??????

    被奪一切后她封神回歸

    ??????

    【甜爽燃,團(tuán)寵,玄學(xué)】?司扶傾一睜眼,不僅被奪了氣運,人人還讓她滾出娛樂圈。?重活一次,她只想咸魚躺,誰知現(xiàn)在圈內(nèi)人只知拉踩營銷,沒點真本事,不好好磨煉演技,這樣下去還能行?怎么也得收拾收拾。?司扶傾捏了捏手腕,動了。?后來,網(wǎng)上瘋狂罵她不自量力倒貼郁曜,造謠她私生活不檢點,而——?國際天后:今天我能站在這里,多虧了傾傾?top1男頂流:離我妹妹遠(yuǎn)點@郁曜?就連國際運動會官方:恭喜司扶傾拿下第13枚個人金牌,等一個退圈?當(dāng)天,全網(wǎng)癱瘓。?·?史書記載,胤皇年少成名,八方征戰(zhàn),平天下,安宇內(nèi),是大夏朝最年輕的帝王,他完美強大,心懷天下,卻因病死于27歲,一生短暫,無妻無妾,無子無孫,是無數(shù)人的白月光男神。?無人知曉,他再睜開眼,來到了1500年后。?這一次,他看見了他遙想過的盛世大夏。?·?不久后胤皇身份曝光,司扶傾得知偶像竟然就在身邊,她敬佩萬分,只想——?司扶傾:努力奮斗,報效大夏!?胤皇:以身相許?司扶傾:????我一心奮發(fā)上進(jìn)你卻想要我??·?全能顏巔女神×殺伐清貴帝王?從全網(wǎng)黑到封神頂流,順便和男神1v1

    ????
  • ??...

Simple modification

.list{
??list-style:?none;
??margin:?0;
??padding:?0;
??width:?400px;
}
.item{
??position:?relative;
??padding:?10px?10px?10px?34px;
??cursor:?pointer;
??counter-increment:?num;
}
.title::before{
??content:?counter(num)?'?';
??width:?25px;
??line-height:?30px;
??text-align:?center;
??color:?#fff;
??position:?absolute;
??font-size:?14px;
??font-family:?fantasy;
??left:?4px;
??background:?center/100%?100%?url();
}
.title{
??margin:?0;
??padding:?8px?0;
??font-weight:?normal;
}
.sumary{
??margin:?0;
??overflow:?hidden;
??display:?-webkit-box;
??-webkit-box-orient:?vertical;
??-webkit-line-clamp:?2;
??color:?#666;
??font-size:?14px;
??color:?20px;
??height:?0;
}

.item::before{
??content:?'';
??position:?absolute;
??inset:?0;
??border-radius:?8px;
??opacity:?0;
??z-index:?-1;
??background:?linear-gradient(270deg,?rgb(241,?236,?249)?0%,?rgba(241,?236,?249,?0)?100%);
}

The effect is as follows

CSS tip: Use transition to retain hover state

Now add the effect of hover

.item:hover?.title{
??color:?rebeccapurple;
}
.item:hover?.sumary{
??height:?40px;
}
.item.item:hover::before{
??opacity:?1;
}

The effect is as follows

Kapture 2022-09-17 at 13.12.45

##Very normal

hover effect, Nothing special, so how to retain the last state after moving out? Then read on

2. Retain the status of

hover

You need to use such a little trick to achieve

hover retention status.

For example, add a

hover style to an element

el:hover{
??color:?red
}

Kapture 2022-09-17 at 13.18.58

If we add a delay to this element

el{
??transition-delay:?1s;
}
Then, there will be a delay when the mouse moves in and out

Kapture 2022-09-17 at 13.20.43

Then, we cancel the delay when

hover

el:hover{
??color:?red;
??transition-delay:?0s;
}
Then, the mouse will respond quickly when moving in, and there will still be a delay when moving out.

Kapture 2022-09-17 at 13.24.09

I believe everyone understands this, if the delay is set to enough Large, such as

el{
??transition-delay:?9999s;
}
, after the mouse is moved out, it needs to go through

9999s before it changes to its original state, which is equivalent to retaining the hover state

Kapture 2022-09-17 at 13.28.42

The principle is like this, let’s take a look at the actual application

3. After the mouse is moved out of the list, the last selected state will still be retained

According to the above Principle, we can easily achieve retaining the state after

hover, as follows

/*?默認(rèn)?transition?*/
.item::before,
.item?.sumary,
.item?.title{
??transition:?0s?9999s;
}
/*?每一項hover?*/
.item:hover?.title{
??color:?rebeccapurple;
??transition:?none;
}
.item:hover?.sumary{
??height:?40px;
??transition:?none;
}
.item.item:hover::before{
??opacity:?1;
??transition:?none;
}
It should be noted that since it is

transition, so all state changes All need to support transition attributes , such as hiding sumary here is height: 0 instead of display:none, and the selected background Color change, because background-image does not support transition, so I changed it to ::before, and then used opacity alone to control some details, etc. The effect is as follows

Kapture 2022-09-26 at 20.02.53

In this way, after the mouse leaves, the previous state is still retained. But we only need to keep the last one, not all of them. How to deal with it?

這里需要換一種思路,可以這么做,鼠標(biāo)在移入整個列表的時候就清除所有的狀態(tài),這樣就只有當(dāng)前hover的選項才會保留下來,有點類似于JS中的思維,先把所有的.current都移除,再給當(dāng)前項添加.current,實現(xiàn)如下

/*?清除所有hover?*/
.list:hover?.title{
??transition:?none;
??color:?#333;
}
.list:hover?.sumary{
??transition:?none;
??height:?0;
}
.list:hover?.item::before{
??transition:?none;
??opacity:?0;
}

這樣就實現(xiàn)了鼠標(biāo)移出列表后仍然保留上一次的選中態(tài)的功能,有點像單選框的效果,只不過是hover觸發(fā)的,效果如下

Kapture 2022-09-17 at 13.54.53

四、默認(rèn)列表的第一項為選中態(tài)

下面來實現(xiàn)最后一個功能。

這個相對而言比較容易,需要用到:first-child偽類,可以匹配到第一個元素。

不過需要考慮的是優(yōu)先級的問題,這個是默認(rèn)狀態(tài),權(quán)限應(yīng)該是最低的,其他hover樣式都應(yīng)該可以覆蓋它,所以可以放在最前面,如下

/*?初始狀態(tài)(第一個選中)?*/
.item:first-child?.sumary{
??height:?40px;
}
.item:first-child?.title{
??color:?rebeccapurple;
}
.item:first-child::before{
??opacity:?1;
}

/*?清除所有hover?*/

/*?每一項hover?*/

這樣就完美實現(xiàn)了文章開頭的效果

Kapture 2022-09-17 at 14.04.17

由于是 CSS 實現(xiàn),多個列表也是完全復(fù)用的

Kapture 2022-09-26 at 20.22.33.gif

完整代碼可以查看線上 demo:CSS keep hover(runjs.work)

五、總結(jié)一下

以上就是通過純 CSS 實現(xiàn)保留鼠標(biāo)滑過樣式的全部技巧了,主要還是對transition-delay的靈活運用,下面總結(jié)一下

  • 實現(xiàn)原理的利用transition-delay,讓“還原”的時間足夠長,這樣就實現(xiàn)了保留hover狀態(tài)的效果了

  • 單選效果可以在鼠標(biāo)移入整個列表的時候就清除所有的狀態(tài),這樣就只有當(dāng)前hover的選項才會保留下來,有點類似于JS中的思維

  • 需要注意所有屬性必須是支持transition的,比如display:none就不支持transition,需要用其他樣式代替

當(dāng)然,整個實現(xiàn)對于 CSS 以及選擇器要求是相當(dāng)高的,實際項目過程中可能并不如 JS 實現(xiàn)來的快,但是,CSS能夠?qū)崿F(xiàn)的又何必動用 JS呢?在我看來,JS就應(yīng)該回歸本職,專心處理數(shù)據(jù)邏輯交互,視覺方面全部交給CSS就行了,只是現(xiàn)在CSS還不夠強大,實現(xiàn)需要用到很多奇技淫巧,但是,CSS現(xiàn)在已經(jīng)在變得足夠強大,比如:has偽類,相信未來CSS會越來越美好

(學(xué)習(xí)視頻分享:css視頻教程、web前端

The above is the detailed content of CSS tip: Use transition to retain hover state. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

PHP Tutorial
1502
276
How to change text color in CSS? How to change text color in CSS? Jul 27, 2025 am 04:25 AM

To change the text color in CSS, you need to use the color attribute; 1. Use the color attribute to set the text foreground color, supporting color names (such as red), hexadecimal codes (such as #ff0000), RGB values (such as rgb(255,0,0)), HSL values (such as hsl(0,100%,50%)), and RGBA or HSLA with transparency (such as rgba(255,0,0,0.5)); 2. You can apply colors to any element containing text, such as h1 to h6 titles, paragraph p, link a (note the color settings of different states of a:link, a:visited, a:hover, a:active), buttons, div, span, etc.; 3. Most

How to purge unused CSS? How to purge unused CSS? Jul 27, 2025 am 02:47 AM

UseautomatedtoolslikePurgeCSSorUnCSStoscanandremoveunusedCSS;2.IntegratepurgingintoyourbuildprocessviaWebpack,Vite,orTailwind’scontentconfiguration;3.AuditCSSusagewithChromeDevToolsCoveragetabbeforepurgingtoavoidremovingneededstyles;4.Safelistdynamic

What is a stacking context? What is a stacking context? Jul 27, 2025 am 03:55 AM

Astackingcontextisaself-containedlayerinCSSthatcontrolsthez-orderofoverlappingelements,wherenestedcontextsrestrictz-indexinteractions;itiscreatedbypropertieslikez-indexonpositionedelements,opacity

Describe different CSS units and when to use them Describe different CSS units and when to use them Jul 27, 2025 am 04:24 AM

In web development, the choice of CSS units depends on design requirements and responsive performance. 1. Pixels (px) are used to fix sizes such as borders and icons, but are not conducive to responsive design; 2. Percentage (%) is adjusted according to the parent container, suitable for streaming layout but attention to context dependence; 3.em is based on the current font size, rem is based on the root element font, suitable for elastic fonts and unified theme control; 4. Viewport units (vw/vh/vmin/vmax) are adjusted according to the screen size, suitable for full-screen elements and dynamic UI; 5. Auto, inherit, initial and other values are used to automatically calculate, inherit or reset styles, which helps to flexibly layout and style management. The rational use of these units can improve page flexibility and responsiveness.

How to use the CSS backdrop-filter property? How to use the CSS backdrop-filter property? Aug 02, 2025 pm 12:11 PM

Backdrop-filter is used to apply visual effects to the content behind the elements. 1. Use backdrop-filter:blur(10px) and other syntax to achieve the frosted glass effect; 2. Supports multiple filter functions such as blur, brightness, contrast, etc. and can be superimposed; 3. It is often used in glass card design, and it is necessary to ensure that the elements overlap with the background; 4. Modern browsers have good support, and @supports can be used to provide downgrade solutions; 5. Avoid excessive blur values and frequent redrawing to optimize performance. This attribute only takes effect when there is content behind the elements.

How to style links in CSS? How to style links in CSS? Jul 29, 2025 am 04:25 AM

The style of the link should distinguish different states through pseudo-classes. 1. Use a:link to set the unreached link style, 2. a:visited to set the accessed link, 3. a:hover to set the hover effect, 4. a:active to set the click-time style, 5. a:focus ensures keyboard accessibility, always follow the LVHA order to avoid style conflicts. You can improve usability and accessibility by adding padding, cursor:pointer and retaining or customizing focus outlines. You can also use border-bottom or animation underscore to ensure that the link has a good user experience and accessibility in all states.

How to center text in CSS? How to center text in CSS? Jul 27, 2025 am 03:16 AM

Use text-align:center to achieve horizontal centering of text; 2. Use Flexbox's align-items:center and justify-content:center to achieve vertical and horizontal centering; 3. Single-line text can be vertically centered by setting line-height equal to the container height; 4. Absolute positioning elements can be combined with top: 50%, left: 50% and transform:translate (-50%, -50%) to achieve centering; 5. CSSGrid's place-items:center can also achieve dual-axis centering at the same time. It is recommended to use Flexbox or Grid first in modern layouts.

What are user agent stylesheets? What are user agent stylesheets? Jul 31, 2025 am 10:35 AM

User agent stylesheets are the default CSS styles that browsers automatically apply to ensure that HTML elements that have not added custom styles are still basic readable. They affect the initial appearance of the page, but there are differences between browsers, which may lead to inconsistent display. Developers often solve this problem by resetting or standardizing styles. Use the Developer Tools' Compute or Style panel to view the default styles. Common coverage operations include clearing inner and outer margins, modifying link underscores, adjusting title sizes and unifying button styles. Understanding user agent styles can help improve cross-browser consistency and enable precise layout control.

See all articles