是否有默认,标准,推荐或众所周知的图标表示链接将打开新的浏览器窗口?
这是出于Web可访问性的原因。还是基本上所有人都免费?
我意识到,那些能够充分利用它们的用户(使用屏幕阅读器)甚至不会在乎图像的外观,而对替代文本更感兴趣。
决定去这个:
除非有人可以提出一个被更广泛采用的建议?
Answers:
没有已经建立的标准图标。
例如,您选择的图标类似于Wikipedia中用于标记指向外部网站(不属于Wikipedia)的链接的图标。但是,您可以在网站上使用它,从而在自己的页面中建立约定。只需确保操作一致即可:标记有该图标的所有链接都必须打开到新页面,而未标记该图标的所有链接都应在同一页面中打开。如果您拥有稳定的用户基础,并且他们有机会习惯您的约定,则可以改善可访问性。如果您的网站主要是由一次性访问者访问的,那么您只会增加视觉混乱。
我参加这个聚会很晚,但是看看我在CodePen中发现了什么!
a[target="_blank"]::after {
content: url();
margin: 0 3px 0 5px;
}
<a class="external" href="https://example.org" target="_blank">external link</a>
a[target="_blank"]:after
,我手中的冒号可与Safari 11.1和Firefox 61一起使用。哪个浏览器需要双冒号?请随时编辑答案。谢谢
display:inline-block; vertical-align:text-top;
了我的显示问题。谢谢。
对于许多Unicode字符,您需要使用以下字体(至少对于Windows而言,如果可以测试,请对Linux和Mac进行注释):
a:link {font-family: 'Segoe UI Symbol' !important;}
同样,您可以应用CSS选择器以如下方式使用该target
属性:
a[target='blank']
a[target]
请记住,浏览器对 a
选择器,因此a:link
/ /a:visited
一定要考虑一下。
Unicode“两个连接的正方形”字符:
http://www.fileformat.info/info/unicode/char/29c9/index.htm
的CSS
a[target='_blank']::after {content: '\29C9';}
支持
Mac OS X,优胜美地:2种字体Apple Symbol
和STIXGeneral
Unicode“带有右上象限的白方块”字符:
http://www.fileformat.info/info/unicode/char/25F3/index.htm
的CSS
a[target='_blank']::after {content: '\25F3';}
支持
Mac OS X中,优胜美地:3种字体Apple Symbol
,STIXGeneral
,Menlo
。
Unicode“右上阴影白色方形”字符:
http://www.fileformat.info/info/unicode/char/2750/index.htm
的CSS
a[target='_blank']::after {content: '\2750';}
支持
Mac OS X的10.10约塞米蒂有三种字体:Arial Unicode MS
,Menlo
和Zapf Dingbats
。
我会选择这样的东西:
正如其他人提到的那样,您选择的图标已被维基百科和其他网站广泛使用,以表示指向外部网站的链接。但这更多是个人喜好,而不是网络标准。
alt
应使用该属性来描述图像,因此在您的示例中,它可能类似于:alt="New window icon"
。话虽如此,一个title
属性将在悬停上显示一个工具提示,在这种情况下,它对可访问性和可用性非常有用:title="Link opens in a new window"
尽管我现在更喜欢说“新标签”而不是“新窗口”。看看我的完整的答案在这里stackoverflow.com/questions/1899772/...
我能找到的最接近的是NORTH ARROW TO CORNER⇱和SOUTH EAST ARROW到CORNER⇲-但是创建这些图标的人都没有做NORTH EAST ARROW TO CORNER
http://www.fileformat.info/info/unicode/category/So/list.htm
参见此处:https : //codepen.io/Bets/pen/KGBqqb(以下运行片段未正确显示)
编辑:添加了另一个选项,不需要链接后的另一个元素。
.newWindow {
display:inline-block;
margin-left:5px;
position: relative;
border: 1px solid;
width: 8px;
height: 8px;
}
.newWindow:after {
position: absolute;
top:-8px;
right:-2px;
font-size:0.8em;
content:"\1f855";
}
.newWindow:before {
position: absolute;
top: -3px;
right: -3px;
content: " ";
border: 4px solid white;
}
a[target="_blank"] {
position: relative;
}
a[target="_blank"]:after {
position: absolute;
top: 3px;
right: -15px;
content: "\1f855";
font-size: 13px;
color: black;
line-height: 3px;
height: 5px;
width: 5px;
border-right: 2px solid white;
border-top: 2px solid white;
}
a[target="_blank"]:before {
position: absolute;
top: 4px;
right: -15px;
content: " ";
border: 1px solid black;
width: 8px;
height: 8px;
}
<a href="#">Link followed by span</a><span class="newWindow"></span>
<br/>
<a href="#" target="_blank">Just link</a>
a[target="_blank"]::after
。您的解决方案需要在html中为您需要的每个链接添加div。其他解决方案不需要更改html。只会将符号添加到指定了target属性的链接中。
在我的WordPress博客上,我不得不链接到多个站点,这些站点显然禁用了后退按钮(Facebook和Google翻译结果)。对于这些链接,我将其设置为打开新窗口。我收集了一些“新窗口”图标,但是它们总是打断行距(也许是WordPress的事情;图标周围没有多余的空间),所以我决定使用title =“”表示“链接打开新窗口” ”和链接内的文本图标[+],在链接文本的末尾,以空格分隔。
我知道我参加晚会很晚,但是FWIW这是我的解决方法\\(ツ)_ /¯,
HTML:
<a href="#" target="_blank">Your link</a>
jQuery的:
如果您知道此版本的原始JS版本,请告诉我们,我很乐意在此处添加它(我不是JS开发人员😊)
$("a[target='_blank']").attr({title:"Link opens in a new tab"}).addClass("new-tab");
CSS:
.new-tab:after {
display: inline-block;
content: "⇱";
position: relative;
top: -5px;
margin-left: 2px;
transform: rotate(90deg);
}
演示:
这是一支钢笔:https : //codepen.io/anon/pen/MBBXjP(例如,此链接应在新窗口中打开,哈哈)。
多年来,这种技术对我非常有用,因为:
title
每次创建在新标签中打开的链接时都手动添加属性。target="_blank"
,仅此而已。我本来希望能够使用此图标🗗
,但问题是iOS设备不支持该图标,我认为macOS也是如此。
如今,您可以使用备忘单中的Font Awesome 5中的图标-实心图标:
接近所选择的图标。
在查看solid.css时,我注意到字体的名称是“ Font Awesome 5 Free”:
a[target='_blank']::after {
content: ' \f35d';
font-family: "Font Awesome 5 Free";
color: blue;
}
或者,如果您不使用Font Awesome CSS而只想定位字体:
@font-face {
font-family: "FontAwesomeSolid";
font-weight: bold;
font-style: normal;
src : url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.11.2/webfonts/fa-solid-900.ttf") format("truetype");
}
a[target='_blank']::after {
content: ' \f35d';
font-family: "FontAwesomeSolid";
color: blue;
}
好的,我来晚了,但是这是我想出的改善其他所有人答案的方法:
我在这里找到了超级整洁的图标:https:
//icons8.com/icon/43738/external-link在此处缩小/优化了SVG:https://petercollingridge.appspot.com/svg-optimiser
并将生成的SVG的base64嵌入一个CSS样式规则,用于指定em
s中的所有大小:
a[target="_blank"]::after {
content: "";
width: 1em;
height: 1em;
margin: 0 0.05em 0 0.1em;
background: url() no-repeat;
background-size: contain;
display: inline-block;
vertical-align: text-bottom;
}
An <a href="" target="_blank">external link</a> is super pretty! 😁<br />
<span style="font-size: 2em;">In <a href="" target="_blank">all</a> sizes!</span><br />
<span style="font-size: 3em;">Even <a href="" target="_blank">super large</a> ones!</span><br />
<span style="font-size: 0.5em;">And in <a href="" target="_blank">super tiny ones</a> too!</span><br />
它对我来说绝对是惊人的!
我可能永远不会再回到可能的解决方案了。
a[target="_blank"]:not(.no-external-link-icon)::after
这样可以禁用将图标添加no-external-link-icon
到<a>
元素的图标显示。