搜索
首页web前端css教程网页打开新窗口target=_blank不符合标准_经验交流

"there is no attribute target for this element(in this HTML version)"

原来在HTML4.01/XHTML1.0/XHTML1.1严格DOCTYPE下,target="_blank"、target="_self"等等语法都是无效的,我们只能通过JavaScript来变通实现。

有朋友问为什么不允许使用target="_blank"?这个属性很方便啊。呵呵,不知道W3C的专家们是怎么想的,据我所知,主要是“易用性、友好性”的问题,因为老外觉得不经过用户同意,没有明确提示就打开一个新窗口是不礼貌的。先不管这个取消是否合理,我们来看看解决办法。

rel属性
HTML4.0增加了一个新属性:rel,这个属性用来说明链接和包含此链接页面的关系,以及链接打开的目标。rel有许多的属性值,比如next、previous、chapter、section等等。我们要使用的就是rel="external"属性。原来这样写的代码:


打开一个新窗口


现在要写成这样:打开一个新窗口

这是符合strict标准的方法。当然还必须配合一个javascript才有效。

javascript
完整的代码JS如下:

function externallinks() {
 if (!document.getElementsByTagName) return;
 var anchors = document.getElementsByTagName("a");
 for (var i=0; i   var anchor = anchors[i];
   if (anchor.getAttribute("href") &&
       anchor.getAttribute("rel") == "external")
     anchor.target = "_blank";
 }
}
window.onload = externallinks;

你可以把它保存成一个.js文件(比如external.js),然后通过外部联接方法调用:


就是这样。

最后补充一句,我网站采用的target="new"在过渡型DOCTYPE下是允许的,但也不符合strict标准。下次改版时我将采用strict模式,将所有target="new"改成rel="external"。

本文参考了以下文章:

Kevin Yank的《New-Window links in a Standards-Compliant World》 
《Standards-based Replacement for target="_blank" in External links》 
2006.7.13更新
很多门户网站的首页全部是弹出式的,我估计至少在中国这种观念暂时还改不了,在这种情况下就不需要在每个链接下加rel,全代码如下:

<script></script> <script>//<![CDATA[ <BR>function externalLinks() { <BR> if (!document.getElementsByTagName) return; <BR> var anchors = document.getElementsByTagName("a"); <BR> for (var i=0; i<anchors.length; i++){ <BR> var anchor = anchors; <BR> if (anchor.getAttribute("href")) <BR> anchor.target ="_blank"; <BR> } <BR>} <BR>window.onload = externalLinks; <BR>//]]></script>

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
构建我们想要的网络构建我们想要的网络Apr 11, 2025 am 10:55 AM

在Microsoft Edge团队中,我们致力于开放网络并帮助推动创新前进,这就是为什么我们开始了一项新计划

了解网络可访问性颜色对比度和比率了解网络可访问性颜色对比度和比率Apr 11, 2025 am 10:51 AM

当您对网页设计中的颜色对比投诉时,该怎么办?对您来说似乎很好,因为您能够阅读

这样做以改善网站上的图像加载这样做以改善网站上的图像加载Apr 11, 2025 am 10:32 AM

在下面嵌入的视频中,Jen Simmons解释了如何使用宽度和高度属性来改善图像加载。问题是有很多詹克

结识了Skvelte,这是街区上的新框架结识了Skvelte,这是街区上的新框架Apr 11, 2025 am 10:29 AM

在过去的六年中,Vue,Angular和React扎根了前端组件框架的世界。 Google和Facebook有自己的赞助框架,

为什么JavaScript吃HTML为什么JavaScript吃HTMLApr 11, 2025 am 10:28 AM

网络开发总是在变化。最近,尤其是一种趋势已经变得非常流行,这从根本上违背了关于

控制台命令指南控制台命令指南Apr 11, 2025 am 10:14 AM

多年来,开发人员的调试控制台已在Web浏览器中以一种或另一种形式提供。最初是作为错误报告的手段

被盗域名的情况被盗域名的情况Apr 11, 2025 am 10:12 AM

早在2011年,该网站的域名CSS-Tricks.com就被盗了。 “劫持域,”他们称之为。它不仅是这个网站,但大约有12个网站

使用边缘到边缘网格的全宽元素使用边缘到边缘网格的全宽元素Apr 11, 2025 am 10:09 AM

如果您有一个有限的宽度容器,则说一个集中的文本列,“打破”以使全宽元素涉及欺骗。也许是最好的

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)