HTML interestfor属性与悬停popover交互效果

这篇文章发布于 2026年03月4日,星期三,11:36,归类于 CSS相关, HTML相关。 阅读 65 次, 今日 63 次 没有评论

 

一、悬停popover也原生支持了

之前“该使用原生popover属性模拟下拉了”这篇文章有介绍过点击行为驱动的popover下拉。

最近发现,鼠标hover悬停也支持popover交互了。

且功能比点击更丰富,适用范围更广,那就是将popovertarget属性换成interestfor属性。

先看案例,HTML如下:

<button interestfor="imgBook">Hover显示图片</button>
<img id="imgBook" popover src="book.jpg" />

无需任何JS代码,鼠标经过按钮,就可以让图片显示,实时效果如下(需要Chrome 142+浏览器):


Nice!

Nice!

二、链接元素也支持

popovertarget属性仅适用于<button>元素,但是interestfor属性不仅可以用在按钮元素上,也可以用在各类链接元素上,例如<a>元素、<area>元素。

这个不难理解,<a>元素本身就有点击行为,和popovertarget的点击行为是冲突的。

但是interestfor属性是鼠标经过进入行为,并不会和<a>元素本身的链接跳转想冲突。

例如:

<a href interestfor="myAccount">Hover显示内容</a>
<div id="myAccount" popover>我的抖音:“张鑫旭本人”</div>

Hover显示内容

我的抖音:“张鑫旭本人”

悬浮上面的链接元素,就可以在显示器的最中间看到类似下面截图的效果了:

效果示意

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>元素背景高亮了。

实时渲染效果如下:

Hover Me!

鼠标经过链接后我高亮

上面的案例中出现了个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浏览器支持。

interset invokers 兼容性

总之,我是非常期待这个CSS特性能够快速全面支持的。

好吧,就介绍这么多,还是挺实用的一个特性。

飞吻

(本篇完)

分享到:


发表评论(目前没有评论)