文档章节

CSS text-indent: -9999px;

Reya滴水心
 Reya滴水心
发布于 2015/11/11 14:15
字数 843
阅读 640
收藏 1

   建站过过程中朋友喜欢把网站名称用H1表示,但从美观考虑,要用logo图片来代替h1,这时需要隐藏h1内的这段文字,但又不能对搜索引擎不友好,否则就失去了定义h1标签的意义。

   在CSS中如何以图代字,找了一下CSS隐藏文字的方法,有以下几条:

   1、display:none;

   这个大家普遍说法是,搜索引擎可能认为被隐藏的文字属于垃圾信息而被忽略,不为隐藏的对象保留物理占位空间。GG也搜CSS文件?不过如果用这个方法,<h1>如何设计,也是难题。

   2、visibility:hidden;

   和display:none;相对应,为隐藏的对象保留物理占位空间。  

   3、overflow:hidden;

   这是网上用的最多的方法,但是我认为对于隐藏h1标签的“站点名称”文字,不太合适,原因我在最后说。

.texthidden{
  display:block;
  overflow:hidden;
  width:0;
  height:0;
}

  4、positon:absolute;

  用绝对定位将其推出可视区,不过虽然可视性不存在,但仍占据物理空间,与隐藏文字的宗旨相背,另外我个人不喜欢用绝对坐标定位magin这个属性,margin在不同浏览器中总是带来不可预料的Bug。

.texthidden{
  positon:absolute;
  margin-top:-9999px;
  margin-left:-9999px;
}

  5、text-indent:-9999px;

  把h1作为一个块来显示(display:block;),指定长宽(和图片一样大小),然后指定h1的背景图片,也就是将我们需要的图片作为h1这个标签的背景。而h1标签中插入的,仍然是作为字符形式出现的博客标题,然后用text-indent:-9999px;将文字甩到屏幕看不到的地方,9999px应该是足够了,谁的屏幕也没那么大吧。

h1 a{
  height:30px;
  width:165px;
  float:left;
  text-indent:-9999px;
  background-image:url(images/logo.gif);
  background-repeat:no-repeat;
  display:block;
  position:relative;
}

  <h1>

  <ahref=http://www.jshelp.cn/>js助手</a>

  </h1>

  在h1使用上语义明确,符合语义化定义。text-indent就是首行缩进,大家都在中文段落,首行空两格用过它。这里通过负值缩进,使文字超出可视区,而这时h1下的背景就显示出来了,h1中包含的<a>标签又不影响使用,对于隐藏文字“站点名称”应该是最佳方案了。但对于多段文字的隐藏这个方法就不适合了。

  这里还有个问题,就是点击<h1><a>链接时,会产生一个虚线框,对于IE还好,没什么问题,虚线框只是在背影图片大小。但是Firefox就有些麻烦,它把缩进的文字范围也包含进来了,这样不是很美观。

  于是需要屏掉点击时产生的虚线框,IE和FF屏虚线框方法不一样。IE采用的遍历方法(HTC,css表达式)有些耗系统资源,正好我们只需要隐藏FF下的虚线框就行了,IE就不管了,说一下Firefox如何去掉链接的虚线框的方法。

a{
  outline:none;/*去掉Firefox点击时产生的虚线框*/
}

PS:全文都只是作者的观点,至于使用text-indent:-9999px;来解决问题是否可行,有人赞同有人反对。所以还是有待进一步讨论。

本文转载自:http://ajhcc.blogbus.com/logs/41836252.html

Reya滴水心
粉丝 40
博文 88
码字总数 34619
作品 0
深圳
前端工程师
私信 提问
uploadify 取消上传的按钮看不见问题解决方案

uploadify.css,里面的.uploadify-queue-item .cancel a图片url不对,如下: .uploadify-queue-item .cancel a { background: url('uploadify-cancel.png') 0 0 no-repeat; float: right; hei......

qhaiyan
2016/11/22
27
0
请教高手们一个关于wordpress导航栏菜单栏的问题

求助大家个关于wordpress导航栏的问题 我想我的网站的导航栏变成如下样式 我试着在 之间加入如下代码: 首页 并在css中定义class属性为: .home { float: left; height: 48px; width: 54px; ...

穆奕诚
2013/08/31
612
1
请教大家一个关于wordpress的wp_nav_menu函数和style.css的问题

我在二次开发主题遇到困 原来主题的header.php中关于wp_nav_menu代码: '; if(function_exists('wp_nav_menu')) { wp_nav_menu(array('theme_location'=>'primary','menu_id'=>'nav','contai......

穆奕诚
2013/08/30
579
0
利用CSS、JavaScript及Ajax实现图片预加载的三大方法

预加载图片是提高用户体验的一个很好方法。图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度。这对图片画廊及图片占据很大比例的网站来说十分有利,它保证...

詹真琦
2013/12/08
189
1
CSS进阶(19)—— CSS中的文本处理(下)

CSS有很多属性专门用来对文本进行控制,由于这些属性的作用机制往往是基于内联盒模型的,因此对于内联块状元素也是有效果的,如我们最常用的text-align:center可以让内联元素水平居中。本章我...

闲人王昱珩
06/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

VMware vSphere ESXi主机的访问控制

在vShpere中,访问ESXi主机的途径很多,如下: ESXi DCUI ESXi Shell ESXi SSH ESXi Host Client vCenter --> vSphere web client / vSphere Client VMware vSphere ESXi主机的访问控制,除了......

大别阿郎
22分钟前
3
0
大神讲解CGI、FastCGI和PHP-FPM关系图解

参考资料 概念了解:CGI,FastCGI,PHP-CGI与PHP-FPM:http://www.nowamagic.net/librarys/veda/detail/1319 php中fastcgi和php-fpm是什么东西:https://www.zybuluo.com/phper/note/50231 ......

网络小虾米
32分钟前
3
0
《DNS攻击防范科普系列3》 -如何保障 DNS 操作安全

引言 前两讲我们介绍了 DNS 相关的攻击类型,以及针对 DDoS 攻击的防范措施。这些都是更底层的知识,有同学就来问能否讲讲和我们的日常操作相关的知识点,今天我们就来说说和我们日常 DNS 操...

Mr_zebra
32分钟前
3
0
zk中ServerCnxn

实现接口Stats, Watcher 内部类 DisconnectReason CloseRequestException EndOfStreamException(流关闭) 属性 方法 getSessionTimeout 获取session失效时间 sendResponse 发送回复数据 se......

writeademo
37分钟前
3
0
如何将 Redis 用于微服务通信的事件存储

来源:Redislabs 作者:Martin Forstner 翻译:Kevin (公众号:中间件小哥) 以我的经验,将某些应用拆分成更小的、松耦合的、可协同工作的独立逻辑业务服务会更易于构建和维护。这些服务(也...

中间件小哥
40分钟前
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部