在新选项卡中显示链接【html中 target=“_blank“】

原因

如果在同一个选项卡中打开链接,那么有可能很难返回到第一页。所以需要考虑在新选项卡中显示链接。

方法

可以通过在 HTML 中的 a 标签中指定 target 属性来指定链接的显示目的地:

html 复制代码
<a href="链接目标URL" target="指定链接显示目标"></a>

指定链接显示目标有以下四种

  • 同一选项卡中打开:_self,这是target的默认值,通常省略

  • 新选项卡中打开:_blank

  • 在新窗口中打开:window.open

  • 在内联框架中打开:

    内联框架(iframe)是指在网页中创建一个独立区域,并在其中加载并显示其他网页等内容。

    通过a标签指定要在内联框架中显示的HTML,使用target属性赋予其专属名称,并使用iframe标签进行显示。

    常用于在同一网页内仅切换特定区域的画面,例如显示价格或菜单等场景。

    示例代码:

    html 复制代码
    <ul>
     <li><a href="sample1.html" target="sample">sample1</a></li>
     <li><a href="sample2.html" target="sample">sample2</a></li>
     <li><a href="sample3.html" target="sample">sample3</a></li>
    </ul>
    
    <div><iframe src="sample1.html" width="250" height="80" name="sample">代替内容</iframe></div>

风险

target="_blank"window.open两种打开方式下,如果不知道正确的设置,在新选项卡中打开链接可能会导致个人信息泄露。

风险示例:"钓鱼网站攻击"

  1. 恶意攻击者制作了一个伪装成大型购物网站的钓鱼网站链接②(表面看起来正常)。
  2. 网站运营者在未察觉链接②是由恶意作者制作的页面的情况下予以刊登。
  3. 用户点击链接②后:
  • 新标签页打开了参考页面;
  • 用户之后返回最初浏览的的网页①;
  • 不知为何,网页①变成了某大型购物网站的登录页面;
  • 用户误以为是真的,输入了账号和密码重新登录;
  • 最终用户的信息被盗取。

安全措施

方法一:

不使用新选项卡,直接使用_self,在当前页面中打开

方法二:

html 复制代码
<a href="目标链接URL" target="_blank" rel="noopener noreferrer">在新标签页中安全打开</a>

noopener 是一种指定,用于禁止访问在新标签页中打开的链接。

由于链接来源和新标签页中打开的链接会被视为不同的对象,因此这也是一种提升性能的措施。

但是,由于某些浏览器可能不支持 noopener,因此建议同时指定 noreferrer 以应对不支持该功能的浏览器。

由于用于在新窗口中打开链接的 window.open 方法也存在安全漏洞,因此必须同时指定 noopenernoreferrer

target="_blank"有时可能无效

在使用a标签的target="_blank"属性时,有时会出现点击URL链接却打不开的情况。

这种现象在计算机上很少见,但在"某些Android设备 + Google Chrome"的组合中尤为常见。

这是因为target="_blank"存在安全漏洞,系统出于安全考虑而阻止其打开。

如果指定了前面提到的"noopener"和"noreferrer",就能解决这个问题,因此当部分浏览器或设备无法打开链接时,请检查rel属性的设置。

相关推荐
canonical_entropy2 小时前
从 Spec-Driven Development 到 Attractor-Guided Engineering
前端·aigc·ai编程
研☆香2 小时前
聊聊前端页面的三种长度单位
前端
给钱,谢谢!2 小时前
React + PixiJS 实现果园成长页:从状态机到浇水动画
前端·react.js·前端框架
暗冰ཏོ3 小时前
VUE面试题大全
前端·javascript·vue.js·面试
次元工程师!3 小时前
LangFlow开发(三)—Bundles组件架构设计(3W+字详细讲解)
java·前端·python·低代码·langflow
Bug-制造者4 小时前
现代Web应用全栈开发:从架构设计到部署落地实战
前端
青春喂了后端5 小时前
IntelliGit 前端状态层重构:把一个全局 Store 拆成清晰的状态边界
前端·重构·状态模式
IT_陈寒5 小时前
Redis内存用爆了,原来我们都忽略了这个配置
前端·人工智能·后端
qq_2518364575 小时前
基于java Web汽车销售管理系统设计与实现
java·前端·汽车