CSS教程:新的图像替换方法

2016-02-19 23:58 23 1 收藏

生活已是百般艰难,为何不努力一点。下面图老师就给大家分享CSS教程:新的图像替换方法,希望可以让热爱学习的朋友们体会到设计的小小的乐趣。

【 tulaoshi.com - Web开发 】

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

现存方法的缺点:

容易失效,例如:图像禁用或者替换图像含有透明区域; 过于复杂不能迅速可靠的执行; 通过js遍历文档树,在页面加载时出现的闪动不尽人意; 可能与一些浏览器不兼容

新的图像替换方法:

新的图像替换技术需要借助于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; 
 }
}

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

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

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

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

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

方法解析

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

针对用户的反应,页面部分内容再格式化; 基于客户端浏览器、设备、和其它状况而附加额外的样式。

状态域方法通过使用下面的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(""), "");
   };

这段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状态域,这很直接了当。

来源:https://www.tulaoshi.com/n/20160219/1630970.html

延伸阅读
标签: Web开发
如何用CSS定义虚线?在CSS中定义虚线一般有两种方法:一种是定义DIV的CSS样式,另一种是通过hr的CSS样式实现。 我们首先需要了解,关于线条的CSS的两个样式: dotted : 在MAC平台上IE4+与WINDOWS和UNIX平台上IE5.5+为点线。否则为实线 dashed : 在MAC平台上IE4+与WINDOWS和UNIX平台上IE5.5+为虚线。否则为实线 水平线条,我们可以用hr...
标签: autocad教程
在对模型进行最后的渲染之前,可以先使用“hide”命令和“shade”命令对模型进行消隐和着色,这样可以比较快速、形象地查看三维模型的整体效果。 23.1.1创建消隐视图 用“hide”命令来创建模型对象的消隐视图,用以隐藏被前景对象遮掩的背景对象,从而使图形的显示更加简洁,设计更加清晰。该命令的调用方式为: 工具栏:“Render(渲染)”...
微信铃声替换方法 一、用电脑修改: 1、下载同步助手或是PP助手或是ITOOLS助手 2、将音乐转换成caf格式,文件名命名为:in.caf 3、用上面的助手软件找:/var/mobile/Applications/*/MicroMessenger.app/这个路径,将in.caf文件替换在该目录下,重启完OK! 二、不用电脑修改 1、下载PP助手、"ifile"软件...
在android中做图像镜像有很多方法,今天算是学习了! 两种方法如下 : 代码如下: //方法一 Matrix matrix = new Matrix(); matrix.postScale(leftOrRight, 1, bmpW/2, bmpH/2);//前两个是xy变换,后两个是对称轴中心点 matrix.postTranslate(x, y); canvas.drawBitmap(bmpLuffy[0], matrix, paint); //方法二 // canvas.save(); //...
标签: Web开发
Conditional-CSS允许你针对单一浏览器或浏览器组写出有逻辑条件的可维护的特定的CSS声明。 使CSS针对特定的浏览器。 简化你对CSS文件的维护。 优化你的CSS。 解决CSS那些使人烦恼的小BUG。 自动扩展和引入@import声明。 它是免费和开源的! 毫无疑问,你会发现很多情况下,不同的浏览器需要不同的样式声明,针对这一点,Conditional-CSS...

经验教程

978

收藏

39
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部