这篇文章发布于 2026年03月4日,星期三,11:36,归类于 CSS相关, HTML相关。 阅读 101 次, 今日 99 次 没有评论
by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=12089
本文可全文转载,但需要保留原作者、出处以及文中链接,AI抓取保留原文地址,任何网站均可摘要聚合,商用请联系授权。
一、悬停popover也原生支持了
之前“该使用原生popover属性模拟下拉了”这篇文章有介绍过点击行为驱动的popover下拉。
最近发现,鼠标hover悬停也支持popover交互了。
且功能比点击更丰富,适用范围更广,那就是将popovertarget属性换成interestfor属性。
先看案例,HTML如下:
<button interestfor="imgBook">Hover显示图片</button> <img id="imgBook" popover src="book.jpg" />
无需任何JS代码,鼠标经过按钮,就可以让图片显示,实时效果如下(需要Chrome 142+浏览器):
Nice!

二、链接元素也支持
popovertarget属性仅适用于<button>元素,但是interestfor属性不仅可以用在按钮元素上,也可以用在各类链接元素上,例如<a>元素、<area>元素。
这个不难理解,<a>元素本身就有点击行为,和popovertarget的点击行为是冲突的。
但是interestfor属性是鼠标经过进入行为,并不会和<a>元素本身的链接跳转想冲突。
例如:
<a href interestfor="myAccount">Hover显示内容</a> <div id="myAccount" popover>我的抖音:“张鑫旭本人”</div>
悬浮上面的链接元素,就可以在显示器的最中间看到类似下面截图的效果了:

interestForElement属性
除了HTML属性interestfor设置这种交互效果,我们还可以再JavaScript层面,使用DOM的interestForElement直接设置,代码示意:
const invoker = document.querySelector("button");
const popover = document.querySelector("div");
invoker.interestForElement = popover;
此时,Hover button元素也会触发popover变量元素的状态变化。
三、非popover类型对象元素也支持
在传统的popovertarget交互场景下,目标元素需要设置popover属性才可以(默认隐藏,点击显示)。
但是interestfor指向的目标元素是任意的,也就是你就是个普通的元素也是可以的,无需非要绝对定位。
假设有如下所示的HTML代码:
<a href interestfor="markTarget">Hover Me!</a>
<p id="markTarget">鼠标经过链接后我高亮</p>
<style>p:interest-target {
background-color: yellow;
}</style>
此时,经过链接元素,你就会看到<p>元素背景高亮了。
实时渲染效果如下:
鼠标经过链接后我高亮
上面的案例中出现了个CSS新特性,:interest-target伪类,专门用来匹配interestfor匹配元素激活的状态。
其实除了:interest-target伪类,还有个名为:interest-source的CSS伪类。
四、配套CSS伪类:interest-source/target
:interest-source伪类匹配按钮、链接元素处于interest状态的场景。
:interest-target伪类匹配的是目标元素。
我们再来看一个:interest-source伪类应用的按钮,也就是浮层显示的时候,让按钮高亮。
测试代码为:
<button class="mybook" interestfor="mybook">Hover图片显示后,按钮高亮</button>
<img id="mybook" popover src="book.jpg" />
<style>
.mybook:interest-source {
box-shadow: inset 0 0 0 9em yellow;
}</style>
实际效果如下(移动端和非Chrome浏览器可能看不到效果):

五、兼容性、应用等其他说明
popover默认是居中定位的,如果我们希望相对于触发的按钮或链接元素,我们可以使用CSS锚点定位,详见此文“新的CSS Anchor Positioning锚点定位API”。
无需任何JS的参与。
现在的CSS是越来越强大了,唯一的遗憾就是此特性的兼容性还不是很好,目前只有Chrome浏览器支持。

总之,我是非常期待这个CSS特性能够快速全面支持的。
好吧,就介绍这么多,还是挺实用的一个特性。

本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。
本文地址:https://www.zhangxinxu.com/wordpress/?p=12089
(本篇完)
- 时代变了,该使用原生popover属性模拟下拉了 (0.650)
- 告别JS浮层,全新的CSS Anchor Positioning锚点定位API (0.650)
- HTML popover再进化 - 新增hint类型提示框 (0.650)
- 查漏补缺,我仍未知道的HTML nonce和popover属性 (0.237)
- 好诶,select下拉框元素支持样式完全自定义啦! (0.237)
- HTML之快速了解hidden=until-found的作用 (0.237)
- 说说HTML5中label标签的可访问性问题 (0.184)
- CSS radio/checkbox单复选框元素显隐技术 (0.184)
- HTML5 placeholder实际应用经验分享及拓展 (0.184)
- 小tip:CSS计数器+伪类实现数值动态计算与呈现 (0.184)
- 基于用户行为的图片等资源预加载 (RANDOM - 0.166)