html图片不停替换,CSS 新的图像替换方法

检查图片是否禁用

该方法检查图片是否禁用,并不是请求服务器上的图片,因为那样会导致一次额外的http请求。作者创建了一个巧妙的方法。

在大多数浏览器中,Image对象可以实例化并追溯到一个无效的URL(http://0),这样很容易检测Image的状态。如果禁用,onerror事件将触发,在js文件的开头,j建立一个新的图像对象:

var img = new Image();

但是,有两个古怪的浏览器对此方法并不兼容。在Gecko浏览器中,不论Image是否被禁用。Onerror事件总是被触发。所幸的是,另外一种可行的方案可以解决此问题--给html元素附加一个无效的背景图片,然后通过getComputedStyle方法获得style属性。如果Image禁用,其属性为none或url( invalid-url:):

if (img.style.MozBinding != null)

{

img.style.backgroundImage = "url(" + document.location.protocol + "//0)";

var bg = window.getComputedStyle(img, '').backgroundImage;

if (bg != "none" && bg != "url(invalid-url:)" || document.URL.substr(0, 2) == "fi")

{

document.enableStateScope("images-on", true);

}

}

另外一个富有挑战性的浏览器是safari,如果请求是一个无效的URL,safari的状态栏将出现错误提示,但页面布局不受任何影响。如果用户的状态栏处于开启状态,报错将一直持续,这很不专业,同样,作者研究了另外一种可行的方案。如果Image来自于1*1的gif图像,且被数据编码。如果Image禁用,其宽度将为0,以下为在safari中测试的情况:

else

{

img.style.cssText = "-webkit-opacity:0";

if (img.style.webkitOpacity == 0)

{

img.onload = function()

{

document.enableStateScope("images-on", img.width > 0);

}

img.src =

"data:image/gif;base64," +

"R0lGODlhAQABAIAAAP///wAAACH5BAE" +

"AAAAALAAAAAABAAEAAAICRAEAOw==";

}

}

最后,对于其它浏览器,在开始初始化Image对象时,仅仅需要测试onerror触发事件。

else

{

img.onerror = function(e)

{

document.enableStateScope("images-on", true);

}

img.src = "about:blank";

}

状态域是可以切换的

可以创建一个系统让用户在文本和替代图像之间切换。

class属性添加到html之上而不是body或其它子元素之上,主要原因在于在图像替换之前,body需要全面加载。如果“image-on”不添加到html之上。当状态域启用时,将会出现闪动。

图像替换技术是css中相当重要的一部分。鉴于现存图像替换技术的缺点,作者花大量时间另辟蹊径,方法独到,值得借鉴。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值