所谓“图片式标题/按钮”,是指文字图片化的标题/按钮。比较熟悉的就是淘宝网首页了哈~~
上面右图(或上图,若是是普屏)的“便民服务”、“卡券&票务”,开小差,忘记圈了~~html
第一层:面向普通情况下的普通用户
这一层是把图片做为了万能手。举个例子,凡客首页(记得之前凡客首页的选项卡文字都是图片式的)顶部的搜索按钮。咱们使用小bug(firebug的爱称)看下源代码:
程序员
能够看到,搜索按钮就是个不含任何文本内容的input
标签,no title, no value, no text, 一切的一切都取决于对应的这个background-image.web
这是最初级层次的实现,只针对普通情况下的普通用户。所谓普通情况就是网速还凑合,用户没有禁用图片或是图片服务器没有便秘或干脆罢工;所谓普通用户指的就是那些靠眼睛浏览网页的用户。浏览器
你们都是聪明人,点到为止。服务器
第二层:面向机器、面向开发者,面向普通情况下的普通用户
这一层的用户标签内保留了图片上对应的文字,可是使用的文字隐藏的技术是display:none
或是visibility:hidden
之流。这两个声明隐藏的文字屏幕阅读器是没法抓取的。并且,有可能被搜索引擎酱油化(若是有恶意之嫌)。wordpress
说实话,这种层面的作法有时还不如第一层,花费的额外工夫和收效比低。惟一肯定的优点就是HTML代码的可读性高了点,便于开发者识别与协做。工具
第三层:面向机器、面向开发者,面向普通情况下的普通用户以及特殊用户
第三层是标签内保留了图片上对应的文字,经过一些可用性更高的技术隐藏了。例如淘宝首页的搜索:
测试
能够看到。淘宝网首页的搜索添加了“搜索”文字,并经过CSS text-indent:-9999px将文字隐藏了。//zxx: 我喜欢使用-999em, 由于能够少一个字符,哇咔咔!动画
虽然text-indent
负值在忘记设置overflow:hidden
声明时候可能会有长长虚框(见下截图,来自淘宝网首页),可是,对于这一层的文字隐藏来讲,其为最佳方法。
搜索引擎
首先,从SEO的角度讲,文字能够被抓取;开发人员这边,也能迅速肯定这段HTML的做用,便于开发协做;对于特殊用户例如使用屏幕阅读器的盲人用户,也能知道这里内容与含义;固然,普通用户正常状态下的访问不受影响。
第四层:面向机器、面向开发者,面向将来的开发者,面向特殊情况、普通情况下的普通用户以及特殊用户
与上一层相比,仍是技术实现上的差别。第三层中,文字的隐藏是藏于远方;而这一层,文字的隐藏时藏于文字图片的下方。
隐藏于下方能够应对一些特殊情况,如:
这种状况下,由于文字就在图片的下方,即便图片显示不出来(或延迟显示),文字也会显露出来,丝绝不影响功能使用。这类图片原本就是用来美化与装饰的,怎能左右功能呢?
这就是为什么说这一层多了个“面向特殊情况下的普通用户”!
至于图片后文本隐藏技术,则是下面要讲的内容。
根据我本身的理解:z-index负值可让元素在其第一个含有定位属性(relative/absolute等)的父元素之上显示,该父元素其余子元素之下显示。由于body
算是特殊的顶级定位元素,所以,咱们基本上能够划分两种状况,见下面手工演示图:
提早需知的~~
下面全部的讨论,示例等都是针对淘宝网首页“个人本地生活”一栏几个彩色标题:
这几个标题是使用background-image
定位以及经过text-indent
负值隐藏文字实现。咱们如今要作的就是:保留background-image
定位,文字隐藏使用其余技术。
1. body为定位元素
当要躲猫猫的文字的第一个有定位特性的爸爸就是body的时候,咱们直接对文字元素应用:
position:relative; z-index:-1;
就能够实现效果了。您能够狠狠地点击这里:body为定位元素时文字隐藏技术demo
做为普通状态的普通用户的咱们进去,看到的可能就是个很正常不过的样子,看不到什么猫腻或是玄机。
若是您浏览器有禁用背景图片显示的工具,例如FireFox下的web developer插件:
能够尝试禁用之。若是没有,您也点击点击demo页面上的“背景图切换显示”按钮,手动隐藏标题的背景图。您会惊奇地看到,后面显示出了对应的文字,以下动图显示:
demo页面有源代码,这里就重复不展现了。
利用body定位的局限性
因为文字藏匿于body之上(而非就在标题图片之下),实现该效果是须要特定条件的。即:含标题背景图片元素到body元素间的父级元素不能有背景色或其 他东西遮挡。这个很好理解:依次有a, b, c三栋楼,你住在a楼(background-image为窗帘),想看c楼前的一棵树(隐藏文本),须要的条件是拉开窗帘(无background- image),b楼不挡住视线(无背景色背景图遮挡)。
这里,不得不赞下淘宝的首页,页面的背景色,模块的背景色等都交给了用户(例如咱们修改页面背景色为#beceeb
):
加上没有先前相对定位属性泛滥的状况,这使得基于body实现z-index负值文本隐藏变得无阻碍。
2. 普通元素为定位元素
然而,考虑到现实,标题图片或按钮图片之上有含背景色的父标签是很正常的。所以,基于body定位不少时候是行不通的。这个时候,咱们能够多写点代码,在普通元素上进行z-index文本隐藏。
这里的普通元素指“从文字直系父标签到第一个含有背景的祖先元素间的全部元素(包括这个祖先元素)”。普通元素上添加诸以下面代码便可:
position:relative; z-index:0;
您能够狠狠地点击这里:普通元素下z-index文本隐藏demo
//zxx:可能你跟第一个demo看不出什么差别。实际上,第一个demo标题图片所在的白色背景为body
标签设置的背景色(相关设置CSS未展现);而第二个demo标题图片所在的白色背景为右侧id
为effect
所在的区域的背景色。
对比第一个demo,这里多了点:
#effect { position: relative; z-index: 0; }
效果虽然实现,可是参照“relative的最小化印象原则”,上面code还能够改进,即CSS最好添加在标题图片元素的直系父标签上。
.demo { position: relative; z-index: 0; }
您能够狠狠地点击这里:进一步的z-index文本隐藏demo
兼容IE6+以及其余阿猫阿狗浏览器。
这个技术估计知道的人多,懒得多讲。很简单:标题图片或按钮应用position:absolute
,覆盖在文字之上。
您能够狠狠地点击这里:absolute覆盖实现文字隐藏demo
相似下面的HTML结构:
<h4 class="title title_1"><a href="#"></a>便民服务</h4> <h4 class="title title_2"><a href="#"></a>卡券&票务</h4> <h4 class="title title_3"><a href="#"></a>生活超市</h4> <h4 class="title title_4"><a href="#"></a>外卖&外送</h4>
其中空a
标签就是背景图片所在标签。天然,咱们也可使用img
标签,页面前定位。
本文啰哩吧嗦了这多,其实本意是介绍z-index负值以及在文本隐藏中的实际应用。而后,扯东扯西,就这样了。
不是什么新的内容,我相信确定有很多同行有相似的研究或介绍,天然,也必定有比我这里更好的方法,欢迎分享!
另外,资历有限,文中可能有一些表述不许确之处(例如,body元素是否默认含有定位属性),欢迎指正!
感谢您可以坚持阅读到这里!
最后再插上一句,若是您没法很好地驾驭z-index负值(一是自身理解上不够深入,二是平时糟糕的书写习惯使得页面定位元素、层级混乱),我建议 您仍是老老实实使用absolute覆盖,简单易懂。还有,从实际状况来说,咱们有没有必要为了一点点可用性上的提升如此折腾呢?说句很差听的话,你的站 点若是就那么几个闲得慌的人进来看看的话,你作好第一层就够了;若是你非要对得起本身辛苦的那点工资,text-indent
这种程度足矣。所谓程序员自我实现的知足对于用户来说是没有一点意义的。“多大的平台作多大的事”是有其自身道理的~~~~