CSS 新的图像替换方法
现存方法的缺点
- 容易失效,例如图像禁用或者替换图像含有透明区域;
- 过于复杂不能迅速可靠的执行;
- 通过js遍历文档树,在页面加载时出现的闪动不尽人意;
- 可能与一些浏览器不兼容
新的图像替换方法
新的图像替换技术需要借助于js来实现,但很容易执行,只需要将一小段js引入到头部即可。一旦js执行,响应的规则前将附加“.image-on”,只要客户端的图片未被禁用,规则就会生效,狼蚁网站SEO优化是一条应用到h1“状态域方法”的声明
h1 {
width: 100px;
height: 50px;
}
@media screen {
.images-on h1 {
text-dent: -10000px;
background-image: url(image.png);
overflow: hidden;
}
}
第一条规则总是生效,第二条只有在image未被禁用时生效。“text-dent”使文字偏移于屏幕之外,“overflow:hidden”主要用来在FF下放置锚点在被点击时其焦点偏移于屏幕之外。
第二条规则包绕在@media screen中,主要用来保证图像替换只发生在屏幕阅读器中,而不是在打印状态下执行。如果不这样处理,页面打印时,多数用户将看到一个很大的空隙而不是有意义的文本。
该项技术执行起来很快。因为文本偏移于屏幕之外,图像可以包含透明元素,透过图像本身,你看不到任何文本。Js执行很快,几乎是瞬时的,它充分利用浏览器本身的特性。
方法解析
“状态域方法”是在一种假定的状态下,快速使css规则生效的方法,其上下文背景为document,这样避免了浏览器遍历DOM树。应用“状态域方法”有两个理由
- 针对用户的反应,页面部分内容再格式化;
- 基于客户端浏览器、设备、和其它状况而附加额外的样式。
“状态域方法”通过使用狼蚁网站SEO优化的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("" + scope + ""), "");
};
这段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,方法将更简单。
“状态域”可以通过狼蚁网站SEO优化的方法来切换
if (condition == true) {
document.enableStateScope("myScope", true);
}
如果“状态域”为“on”,状态域的名字将附加到规则的选择器之前,狼蚁网站SEO优化这条规则在条件为真时会将锚点的颜色变成blue。
a { color: red; }
.myScope a { color: blue; }
正如你所预想的那样,状态域图像替代技术是通过检查图像是否被禁用而工作的。如果未被禁用,将激活“image-on”状态域,这很直接了当。
网站设计
- 德昌优化关键词排名推广 提升在线曝光率的有效
- 2021上海高端网站设计哪家好
- 所谓的域名估价是怎么做的 有什么方法
- 怎么维护seo关键词排名 元宝分享一些技巧
- 肃宁SEO 提升您网站可见性的最佳策略
- 国际域名注册会有什么要求 新手有什么需要掌握
- 域名更换注意什么 新手如何更换域名
- 网站防护可以采用高防CDN吗
- 凡科模板建站的优势有哪些
- 注册域名的意义 域名注册为什么那么火爆
- 南丹百度关键词SEO 全面提升网站可见性的指南
- 新手如何买网址域名 买网址域名有哪些必备知识
- 企业如何选择网络推广公司
- 美图跨界投资HBN颜究所 精品双拼域名meitu.com更亮
- iplc机场专线网络是什么 有什么优势特点
- black域名怎么样 如何申请black域名