实现a元素href URL链接自动刷新或新窗口打开

这篇文章发布于 2019年10月13日,星期日,23:52,归类于 JS实例。 阅读 7431 次, 今日 28 次 19 条评论

 

新窗口智能打开占位图

一、需求描述

希望实现这样一个功能:点击一个链接,如果这个链接浏览器已经打开过,则刷新已经打开的链接窗口;如果这个链接没有打开过,则使用新窗口打开这个链接页面。

这是一个非常好的体验增强功能,可以有效避免浏览器选项卡中打开重复多余的页面。

关键是如何实现呢?

其实很简单,并不需要JS的参与,HTML本身特性就可以实现这样的需求。

二、你可能不知道的target属性特性

无论是<a>链接元素还是<form>表单元素都有一个名叫target的属性,支持的值包括下面这些:

  • _self:默认值。当前浏览器上下文。
  • _blank:通常是一个新的标签页,但是用户可以配置浏览器,是否在新窗口打开。
  • _parent:当前浏览器上下文的的父级上下文,如果没有父级,则行为类似_self
  • _top:最顶级的浏览器上下文。如果没有祖先上下文环境,则行为类似_self.

几乎所有的文档都是上面这样的描述。

但是实际上,target还有一个隐藏特性,那就是可以指定为具体的URL地址或者任意自定义的名称。

例如:

<a href="blank.html" target="blank.html">空白页</a>

此时,如果浏览器已经有标签页的地址是blank.html,则点击上面的链接并不会打开新窗口,是直接刷新已经打开的blank.html;如果浏览器中没有地址是blank.html的标签页,则此时target属性的行为表现类似'_blank'

也就是说,我们要想实现链接地址自动刷新和新窗口打开的这个需求,知道设置链接元素和表单元素的target属性值为目标URL地址值就好了。

您可以狠狠地点击这里:链接新窗口打开或者刷新demo

点击任意这几个链接,可以体验效果。

点击任意链接测试

可以看到,target="blank.html?s=1"target="blank.html?s=2"会认为是两个独立的页面,不会互相刷新。因此,如果想要实现所有的搜索结果页都使用一个标签页选项卡,需要使用其他办法,很简单,指定为相同的值即可,例如:

<a href="blank.html?s=1" target="_search">空白页?s=1</a>
<a href="blank.html?s=2" target="_search">空白页?s=2</a>

三、结束语

要想实现<a>元素href链接自动刷新或新窗口打开的功能,只需要设置target属性值和href属性值一样就好了。

这个特性IE浏览器,Firefox浏览器,以及Chrome浏览器都是支持的,放心使用。


由于老备案凉了,目前网站架在香港主机上,所以访问速度可能略微有些慢,等老备案注销新备案成功,会恢复,可能要3周时间。

为了少点迁移麻烦,所以本月更新内容不会频繁。

最后,安利下,我的新书《CSS选择器世界》签名版淘宝也可以购买了。

淘宝购买二维码

感谢支持!

(本篇完)

分享到:
×
×


发表评论(目前19 条评论)

  1. Redon说道:

    感谢!解决了我头疼的一个刷新小困惑

  2. saber酱说道:

    学到了!

  3. DeathGhost说道:

    研究的够精细的,厉害 👻👻👻👻

  4. chen说道:

    厉害了

  5. PX说道:

    想知道作者怎么知道的

  6. abc说道:

    target=’view_window’也可以实现,
    其效果等于忽略了查询参数

  7. mcfog说道:

    这玩意儿要说的话得从大家用frameset frame写页面的时候说起了
    https://www.w3.org/TR/html4/present/frames.html#h-16.3

  8. mt说道:

    学到了。
    不过并非文档并非没有写清楚。
    就拿 mdn 的:
    > Where to display the linked URL, as the name for a browsing context (a tab, window, or ). The following keywords have special meanings for where to load the URL:

    那几个不过是特殊的而已。

  9. webster说道:

    403了

  10. 浮生六记说道:

    我曾经错把_blank打错了,然后对这个属性有一些猜测,没有深入探究,今天终于被证实了

  11. distu说道:

    666,还能这么玩

  12. 似水年华说道:

    最早是在优酷上面发现这个特性的,他是taget=”video”,然后就用在项目里面了,特别好用。

  13. mfk说道:

    如果想要实现所有的搜索结果页都使用一个标签页选项卡,需要想想其他办法

    很简单,把target设成任意一个一样的字符串即可。target不一定要设成url或内置的那4个,可以是任意字符串。

  14. dii说道:

    demo试了不行,target去掉参数可以了

  15. meepo说道:

    这个特性有一种蓦然回首的感觉

  16. a说道:

    学到了,太实用了

  17. Miyang说道:

    深夜学到了