十种图片替换文本CSS方法

十种图片替换文本CSS方法(转)

很多网站的logo都使用图片替换文本来实现,而且在一些情况下也有使用图片效果来替换难以实现的文本效果。这些制作我想大家在平时制作中都或多或少的碰到过,那么今天我老话重谈,整理了十种图片替换文本的制作方法。希望对大家有所帮助。

制作原理:

使用图片替换文本,其原理是相当的简单:就是在样式中使用背景图片来替换掉HTML模板中的文本内容,从而达到一种样式无法实现的页面渲染效果。使用图片替换有其优点也有其缺点,优点就是能实现一些特殊的页面效果,缺点就是需要加载图片,而且一些不好的替换方法给残障人员浏览网页会造成一定的不良之处,另外据说会对搜索引擎的搜索有影响,对于这一点没有考究过。那么我们也不去控寻这方面的问题,我们一起来看今天所要说的图片替换文本的制作方法

方法一:

HTML Markup

<h1 id="technique-one">
  <a href="#">yijile.com</a>
</h1>

CSS Code:

#technique-one {
    width: 329px;
    height: 79px;
    background-image: url(images/logo.png);
}
#technique-one a {
    display: none;
}

这种方法被称为“FIR”方法, Joe Clark在《Facts and Opinion About Fahrner Image Replacement》一文中有做深入的介绍。使用这种方法需要注意两点:

  1. 结构性需要增加一个标签包裹文本;如上面的HTML Markup所示;
  2. 需要把背景图设置在外标签上,并且将文本外标签隐藏。

这种方法有一个不好的地方就是不利于阅读器浏览网页。

方法二:

HTML Markup

<h1 class="technique-two">yijile.com</h1>

CSS Code

.technique-two {
    width: 2329px;
    height: 79px;
    background: url(images/logo.png) no-repeat top right;
    margin: 0 0 0 -2000px;
}

这种方法是Radu Darvas创建的,使用负margin配合宽度来制作。如果运用在简单之处,此方法可行,但对于复杂的布局中,大家还需慎用。因为其有可能会影响你的页面布局。

方法三:

HTML Markup

<h1 class="technique-three">yijile.com</h1>

CSS Code

.technique-three {
    width: 329px;
    height: 79px;
    background: url(images/logo.png);
    text-indent: -9999px;
}

这种方法是由Mike Rundle创建,并且简称为Phark方法,也是目前使用图片替换文本常和的方法。这种方法简单易懂而且支持阅读器之类浏览网页。其关键之处使用“text-indent属性,并且给其设置一个较大的负值,达到隐藏文本的效果,”如果你想了解的更深可以参考一下Malarkey Image Replacement (MIR)

方法四:

HTML Markup

<h1 class="technique-four">
  <a href="#">
   <img src="images/logo.png" alt="yijile.com" />
 </a>
</h1>

CSS Code

.technique-four {
    width: 329px;
    height: 79px;
    background: url(images/logo.png);
    text-indent: -9999px;
}

这种方法,我不知道来自源于何处,也不知道其有什么优势之处,可以说他和方法三没有多大的区别,只是上面的替换的是文本,下面是替换的图片而以。这样使用我至今没有整明白是为什么?不知道是不是和SEO方面有关系。无从考究,先放上来给大家参考一下。

方法五:

HTML Markup

<h1 class="technique-five">
  <img src="images/blank.gif" alt="yijile.com" />
  <span>yijile.com</span>
</h1>

CSS Code

.technique-five {
    width: 329px;
    height: 79px;
    background: url(images/logo.png);
}
.technique-five span {
    display: none;
}

这种方法有一个特别之处我们此处使用一个透明的gif图片,通过在img标签中的“alt”属性来弥补display:none。这样阅读器之类的就能阅读到所替换的文本是什么。

方法六:

HTML Markup

<h1 class="technique-six">yijile.com</h1>

CSS Code

.technique-six {
    width: 329px;
    padding: 79px 0 0 0;
    height: 0px;
    font-size: 0;
    background: url(images/logo.png);
    overflow: hidden;
}

这种方法是由Seamus LeahyStuart Langridge发明。使用零高度来隐藏文本,但为了显示背景图片,需要设置一个与替换图片一样的大小的padding值。

方法七:

HTML Markup

<h1 class="technique-seven">
    <span>yijile.com</span>
</h1>

CSS Code

.technique-seven {
    width: 329px;
    height: 79px;
    background: url(images/logo.png);
}
.technique-seven span {
    display: block;
    width: 0;
    height: 0;
    font-size: 0;
    overflow: hidden;
}           

Leon Dwyer想出的这种方法,通过把span的大小都设置为“0”,来达到隐藏文本效果,这样阅读器就能完全阅读到,而且又达到了图片替换文本的效果。真是好方法。

方法八:

HTML Markup

<h1 class="technique-eight">
  <span></span>yijile.com
</h1>

CSS Code

.technique-eight {
    width: 329px;
    height: 79px;
    position: relative;
}
.technique-eight span {
    background: url(images/logo.png);
    position: absolute;
    width: 100%;
    height: 100%;
}

Levin Alexander。这种方法在利用一个空白的span标签来放置背景图片,并对其进行绝对定位,使用覆盖文本,达到隐藏替换文本的效果。

方法九:

HTML Markup

<h1 class="technique-nine">yijile.com</h1>

CSS Code

.technique-nine {
    width: 329px;
    height: 79px;
    background: url(images/logo.png);
    font-size: 1px;
    color: white;
}

Levin Alexander写的这种方法很独特,设置字体为微小值,但这里需要注意一点不能忘了设置字体色和替换图片色一样,不然会有一个小点显示出来。

方法十:

HTML Markup

<h1 class="technique-ten"><span>yijile.com</span></h1>

CSS Code

.technique-ten {
    width: 329px;
    height: 79px;
    background: url(images/logo.png);
}

.technique-ten span {
    border: 0 !important;
    clip: rect(1px 1px 1px 1px);
    clip: rect(1px,1px,1px,1px);
    height: 1px !important;
    margin: -1px;
    overflow: hidden;
    padding: 0 !important;
    position: absolute !important;
    width: 1px;
}

Jonathan Snook使用css的clip属性来实现图片替换文本的效果,详细可以参考Hiding Content for Accessibility

上面主要搜集了十种图片替换文本的CSS制作方法,希望对大家有所帮助。具体采用哪一种方法来运用到你的项目中,你可以根据你自己的需求来选择。最后大家可以看看在线的效果。如果你还有其他的实现方法,可以直接在评论中留下你的方法。

转自:W3CPLUS

转载请注明转自:一极乐http://yijile.com/log/130.html


话题相关文章

话题标签

代码HTMLCSS

一极乐 为乐趣而生

《十种图片替换文本CSS方法》  发表时间:  最后更新时间:

谁来过

不知子曰邀请你对本文不足说出你的看法!

有 10 条评论

  1. 不知子曰

    比较多的情况是用在logo上
    一般页面img都应用在内容上
    css用来实现界面的美化
    比如多说的 喜欢 按钮的红心就没必要插个图就可以使用背景图
    然后一边浏览器会先下载img,而css背景图是读取到了元素才开始下载

  2. 卡卡西

    什么情况下用这个东西。不明白啊。

  3. 子曰去哪

    表示只用过你的第二种

  4. 9527

    我个人最常用的三种:1. 用 padding 撑开,2. 给 text-indent 取负值,3. 设置超 line-height。

  5. 子曰去哪

    是的,很值得我们学习

  6. XMChen

    我一向都是用第三种方法的。还不知道原来有这么多种。

  7. 子曰去哪

    我可能用的最多也就是第一种,但是没有想到如何去隐藏文字,因为经常是瞎撞。

  8. CzBiX

    这么纠结

  9. 子曰去哪

    其实我们可以举一反三,,说不定在下次写模版可以得到很多启发,当然不是停留在用图片替换文字。

  10. 西门

    大漠哥的博客代码都很强啊




博主推荐专题

佛学资料Typecho模版代码乐知道CSS百度CyanogenMod
搜索引擎提交入口言辞


关闭

标签云

一极乐 衷心接受你的建议

TOP