图像替换新技术:状态域方法[译]

作者:dishuipiaoxiang 来源:蓝色理想 时间:2009-08-06 16:41:00 

熟悉css的开发者一定知道图像替换技术,也深知它的意义,Dave Shea 曾在他的一篇文章对此做了详细的总结,参看 Dave Shea’s excellent summaryPaul Young 在分析现存的所有方法的优缺点之后,提出了一种新的方法,并将其命名为“状态域方法”(The State Method),本文将详细介绍该方法的原理:

现存方法的缺点:

  1. 容易失效,例如:图像禁用或者替换图像含有透明区域;

  2. 过于复杂不能迅速可靠的执行;

  3. 通过js遍历文档树,在页面加载时出现的闪动不尽人意;

  4. 可能与一些浏览器不兼容

新的图像替换方法:

新的图像替换技术需要借助于js来实现,但很容易执行,只需要将一小段js引入到头部即可。一旦js执行,响应的规则前将附加“.image-on”,只要客户端的图片未被禁用,规则就会生效,下面是一条应用到h1“状态域方法”的声明:

h1 {
 width: 100px;
 height: 50px;
}

@media screen { 
 .images-on h1 {
   text-indent: -10000px;
   background-image: url(image.png);
   overflow: hidden; 
 }
}


第一条规则总是生效,第二条只有在image未被禁用时生效。“text-indent”使文字偏移于屏幕之外,“overflow:hidden”主要用来在FF下放置锚点在被点击时其焦点偏移于屏幕之外。

第二条规则包绕在@media screen中,主要用来保证图像替换只发生在屏幕阅读器中,而不是在打印状态下执行。如果不这样处理,页面打印时,多数用户将看到一个很大的空隙而不是有意义的文本。

该项技术执行起来很快。因为文本偏移于屏幕之外,图像可以包含透明元素,透过图像本身,你看不到任何文本。Js执行很快,几乎是瞬时的,它充分利用浏览器本身的特性。

方法解析

“状态域方法”是在一种假定的状态下,快速使css规则生效的方法,其上下文背景为document,这样避免了浏览器遍历DOM树。应用“状态域方法”有两个理由:

  1. 针对用户的反应,页面部分内容再格式化;

  2. 基于客户端浏览器、设备、和其它状况而附加额外的样式。

“状态域方法”通过使用下面的script给html附加一个class。

   document.enableStateScope = function(scope, on)
   {
     var de = document.documentElement;
     if (on)
     de.className += " " + scope;
     else
     de.className = de.className.replace(
       new RegExp("\\b" + scope + "\\b"), "");
   };

这段js有一点小问题,在示例页中切换功能并不生效,我重新修改了一下,代码如下:

function hasClass(ele,cls) {
return ele.className.match(new RegExp('(\\s|^)'+cls+'(\\s|$)'));
}
function addClass(ele,cls) {
if (!this.hasClass(ele,cls)) ele.className += " "+cls;
}
function removeClass(ele,cls) {
if (hasClass(ele,cls)) {
var reg = new RegExp('(\\s|^)'+cls+'(\\s|$)');
ele.className=ele.className.replace(reg,' ');
}
}
document.enableStateScope = function(scope, on) {
var de = document.documentElement;
On ?  addClass(de,scope) : removeClass(de,scope);  
};

上面的hasClass、addClass、removeClass方法借用的是《Pro JavaScript Techniques》提供的方法。如果你使用过jquery,方法将更简单。

“状态域”可以通过下面的方法来切换:

if (condition == true) {
document.enableStateScope("myScope", true);
}

如果“状态域”为“on”,状态域的名字将附加到规则的选择器之前,下面这条规则在条件为真时会将锚点的颜色变成blue。

a { color: red; }
.myScope a { color: blue; }

正如你所预想的那样,状态域图像替代技术是通过检查图像是否被禁用而工作的。如果未被禁用,将激活“image-on”状态域,这很直接了当。

标签:图像,技术,状态
0
投稿

猜你喜欢

  • 如何让用户再次访问我的网站时不需再提交相关信息?

    2010-05-16 15:05:00
  • 布局篇(1)—If you love css …

    2008-04-16 14:14:00
  • jQuery在去除缓存数据的一个失误

    2009-12-14 20:40:00
  • SQL截取字符串函数分享

    2011-11-03 17:07:37
  • 3个比较好用的asp检查函数

    2007-09-24 13:25:00
  • 二级联动下拉菜单javascript源码

    2010-03-16 12:32:00
  • SQL处理多级分类,查询结果呈树形结构

    2012-08-21 10:50:12
  • 简单实用的图片播放器1.0(Javascript + css )

    2008-07-16 10:39:00
  • asp任何连接带密码的access数据库

    2008-04-29 21:36:00
  • ASP处理多关键词查询实例代码

    2008-11-21 17:36:00
  • SQL Server 2005 FOR XML嵌套查询使用详解

    2009-01-06 11:20:00
  • 在asp中通过vbs类实现rsa加密与解密

    2010-05-27 12:18:00
  • MYSQL初学者扫盲

    2009-02-27 13:15:00
  • 一些关于SQL2005+ASP.NET2.0的问题

    2007-09-23 13:01:00
  • [译]如何设计网页小广告(banner)

    2009-10-16 20:40:00
  • Smush it - 一款图片压缩的Firefox插件,很好,很强大!

    2009-04-12 20:09:00
  • SQL SERVER 日志已满的处理方法

    2010-07-31 13:32:00
  • 不同操作系统下的mysql数据库同步

    2008-12-22 14:41:00
  • ASP把数字用逗号每3位隔开显示代码

    2008-01-02 13:11:00
  • 你是真正的用户体验设计者吗? Ⅴ

    2008-04-19 18:32:00
  • asp之家 网络编程 m.aspxhome.com