当前位置: 首页 > news >正文

网上商城网站系统/信阳百度推广公司电话

网上商城网站系统,信阳百度推广公司电话,深圳正规seo,做官网需要多少钱最近在开发一个react项目&#xff0c;项目是用create-react-app脚手架创建的&#xff0c;当我在我的项目的菜单栏中添加了一个打开一个外链的a标签时&#xff0c;我收到了一个来自create-react-app的警告信息&#xff0c;信息内容如下<img alt"opener警告" src&qu…
最近在开发一个react项目,项目是用create-react-app脚手架创建的,当我在我的项目的菜单栏中添加了一个打开一个外链的a标签时,我收到了一个来自create-react-app的警告信息,信息内容如下

<img alt="opener警告" src="http://198.252.107.180/~gongm...; width="100%"/>

意思就是说“在没有rel="noopener noreferrer"属性的a标签中使用target="_blank"存在一定的风险”

这个提示瞬间把我吸引了,以前关于a标签收到的提示都是没有设置alt属性啊什么的,但是也只是提示我说为了显示的友好什么的,这次竟然提示我有风险,面对这种问题,必须一探究竟啊。

查阅了一些资料得到了如下关于a标签一个介绍

当一个外部链接使用了target=_blank的方式,这个外部链接会打开一个新的浏览器tab。此时,新页面会打开,并且和原始页面占用同一个进程。这也意味着,如果这个新页面有任何性能上的问题,比如有一个很高的加载时间,这也将会影响到原始页面的表现。如果你打开的是一个同域的页面,那么你将可以在新页面访问到原始页面的所有内容,包括document对象(window.opener.document)。如果你打开的是一个跨域的页面,你虽然无法访问到document,但是你依然可以访问到location对象。

不看不知道一看吓一跳有木有。主要是两个点是我以前从未在意的

  1. 用target="_blank"方式打开的tab和原始页面占用同一个进程(UI进程)
  2. 新打开的页面能获取到原始页面的document。

第一个问题不用我说都知道是非常需要注意的,新的页面中的所有行为都会间接影响到原始页面的性能。

这里主要研究第二个问题。为此,我做了小小的实验。

opener测试

上图解释:

  • 首先打开了第一个页面,第一个页面只有一个“打开一个新页面”的a标签
  • 点击这个链接,打开了一个新页面。新页面中有一个按钮,“告诉打开我的那个页面,我喜欢林志玲”。
  • 点击新页面的按钮然后回到第一个页面,发现第一个页面多出来了一排红色的文字“我喜欢林志玲”。
  • 停在第一个页面5s钟,第一个页面自动跳转到了百度首页。

上面两个页面的代码分别如下:

opener-test.html

<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head><body><a target="_blank" href="test-opener-2.html">打开一个新页面</a></body>
</html>

opener-test-2.html

<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head><body><h1>我是新打开的页面</h1><button type="button" id="btn">告诉打开我的那个页面,我喜欢林志玲</button><script>document.getElementById('btn').addEventListener('click', function() {var _opener = window.opener;var p = _opener.document.createElement('p');p.innerHTML = "我喜欢林志玲";p.style.color = "#f33";_opener.document.body.appendChild(p);setTimeout(function() {_opener.location.href = "//www.baidu.com";}, 5000)});</script></body>
</html>

新的页面不仅往原始页面添加了一段话,而且还让他离开了原来的页面。

注:在上面的例子中,两个页面位于同一个域下面,如果两个页面位于不同的域,那上面的第一个效果就是不行的,因为不同域的情况下,新页面拿不到opener对象的document,但是location对象是可以拿到的,所以第二个效果任然有效。

怎么禁止上面的行为呢?按照create-react-app的提示信息,给连接加上rel属性,如下:

<a rel="noopener noreferrer" target="_blank" href="https://marvengong.github.io/fastmock-docs/book/">

上面的rel属性值多了一个noreferrer它的作用和noopener是一样的,只是适用于低版本的浏览器。

这样处理后,新打开的页面的window对象上就没有opener和referrer对象了。

http://www.lbrq.cn/news/1249075.html

相关文章:

  • 合肥网站建设-中国互联/新网站友链
  • 免费简历模板word文档/网站关键字优化公司
  • 哪个网站建设公司/自己建网站的详细步骤
  • 常用ppt模板网站/能打开的a站
  • 如何让我的网站被百度收录/淘宝摄影培训推荐
  • 南充建网站/网站seo具体怎么做?
  • 做最好的导航网站/搜索引擎网站有哪些
  • VS2010做网站登录页面步骤/网站没有友情链接
  • 网络工程和软件工程哪个好/郑州网站优化渠道
  • 运河经济开发区建设局网站/站长工具的网址
  • 网站建设公司浙江/互联网广告营销是什么
  • 榆林做网站/防晒霜营销软文
  • 外国做问卷可以赚钱的网站/正规的推文平台
  • 网站建设业务员招聘/阿里云万网域名查询
  • 建站网站教程视频/淘宝运营培训机构
  • 海淀网站设计公司/郑州网站建设哪家好
  • 免费网站建设ppt/重庆seo技术教程博客
  • 烟台市建委网站/开发网站用什么软件
  • 网站建设说明/西安官网seo公司
  • 网站制作推广/镇江seo公司
  • 缪斯国际设计公司官网/鸡西seo
  • 大气蓝色企业网站模板/企业做推广有用吗
  • 网站建设和编程/华为seo诊断及优化分析
  • 医疗网站优化怎么做/搜索引擎优化网页
  • 大连科技网站制作/爱链接
  • 传奇页游平台/枫林seo工具
  • 网站建设受众/semi final
  • 嘉兴企业网站建设/关键词搜索排名软件
  • 哪个网站可以做化学实验/网站建设公司业务
  • 网站建设zhuitiankeji/百度大数据
  • STM32学习笔记4-OLED外部中断和中断系统
  • npm 与 npx 区别详解。以及mcp中npx加载原理。
  • “物联网+职业本科”:VR虚拟仿真实训室的发展前景
  • 如何设计一个开放授权平台?
  • 机器学习——朴素贝叶斯
  • Leetcode题解:739每日温度,用单调栈解决问题!