Welcome to the website navigation,本站只接受合法正规的企业网站,欢迎站长们提交你的网站获得展示和流量有任何问题请联系站长,欢迎大家加入本站。

                
提交网站
  • 网站:76083
  • 待审:5
  • APP:577
  • 文章:304411
  • 会员:56004
文字内链包年1000元 文字内链包年1000元 文字内链包年1000元 AI办公网站 AI绘画工具 AIchat

名站导航为爱好css的朋友们提供相关的知识。

纯css教程 圆角实现代码fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

这个方法其实并不完美,其实只是利用了”无限接近”的一个概念。看放大后的图的话,可以很清楚地看到锯齿状。fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

  • 此篇文章具体介绍如下
参看 Dave Shea’s excellent summaryPaul Young 在分析现存的所有方法的优缺点之后,提出了一种新的方法,并将其命名为“状态域方法”(The State Method),本文将详细介绍该方法的原理:

现存方法的缺点:fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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

新的图像替换方法:fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

新的图像替换技术需要借助于js来实现,但很容易执行,只需要将一小段js引入到头部即可。一旦js执行,响应的规则前将附加“.image-on”,只要客户端的图片未被禁用,规则就会生效,下面是一条应用到h1“状态域方法”的声明:fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

h1 {
 width: 100px;
 height: 50px;
} fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

@media screen { 
 .images-on h1 {
   text-indent: -10000px;
   background-image: url(image.png);
   overflow: hidden; 
 }
}fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

第一条规则总是生效,第二条只有在image未被禁用时生效。“text-indent”使文字偏移于屏幕之外,“overflow:hidden”主要用来在FF下放置锚点在被点击时其焦点偏移于屏幕之外。fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

第二条规则包绕在@media screen中,主要用来保证图像替换只发生在屏幕阅读器中,而不是在打印状态下执行。如果不这样处理,页面打印时,多数用户将看到一个很大的空隙而不是有意义的文本。fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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

方法解析
fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

“状态域方法”是在一种假定的状态下,快速使css教程规则生效的方法,其上下文背景为document,这样避免了浏览器遍历DOM树。应用“状态域方法”有两个理由:fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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

“状态域方法”通过使用下面的script给html附加一个class。fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

   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"), "");
   };
fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

这段js有一点小问题,在示例页中切换功能并不生效,我重新修改了一下,代码如下:fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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);  
};
fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

上面的hasClass、addClass、removeClass方法借用的是《Pro JavaScript Techniques》提供的方法。如果你使用过jquery,方法将更简单。
fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

“状态域”可以通过下面的方法来切换:fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

if (condition == true) {
document.enableStateScope("myScope", true);
}
fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

如果“状态域”为“on”,状态域的名字将附加到规则的选择器之前,下面这条规则在条件为真时会将锚点的颜色变成blue。fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

a { color: red; }
.myScope a { color: blue; }
fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

正如你所预想的那样,状态域图像替代技术是通过检查图像是否被禁用而工作的。如果未被禁用,将激活“image-on”状态域,这很直接了当。
#p#副标题#e#
fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

检查图片是否禁用fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

该方法检查图片是否禁用,并不是请求服务器上的图片,因为那样会导致一次额外的http请求。作者创建了一个巧妙的方法。fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

在大多数浏览器中,Image对象可以实例化并追溯到一个无效的URL(http://0),这样很容易检测Image的状态。如果禁用,onerror事件将触发,在js文件的开头,j建立一个新的图像对象:fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

var img = new Image();fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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

 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);
   }
 }
fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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

 else
 {
   img.style.css教程Text = "-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==";
   }
}
fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

最后,对于其它浏览器,在开始初始化Image对象时,仅仅需要测试onerror触发事件。fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

   else
   {
     img.onerror = function(e)
     {
       document.enableStateScope("images-on", true);
     }
     img.src = "about:blank";
   }
fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

状态域是可以切换的fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

可以创建一个系统让用户在文本和替代图像之间切换。fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

查看示例(示例文件由Paul Young提供)fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

class属性添加到html之上而不是body或其它子元素之上,主要原因在于在图像替换之前,body需要全面加载。如果“image-on”不添加到html之上。当状态域启用时,将会出现闪动。fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

图像替换技术是css教程中相当重要的一部分。鉴于现存图像替换技术的缺点,作者花大量时间另辟蹊径,方法独到,值得借鉴。fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

示例下载tate-scope-image-replacement.zipfa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

翻译原文:http://www.denisdeng.com/?p=235fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

英文原文http://www.sitepoint.com/article/image-replacement-state-scope/fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

CSS教程 优先级使用技巧fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

fa4AIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

关于css的相关的知识就说到这里希望能够可以帮助更多的朋友们。,CSS,图像替换

标签:CSS图像替换

分享到:

  admin

注册时间:

网站:0 个   APP:3 个  文章:0 篇

  • 76083

    网站

  • 577

    APP

  • 304411

    文章

  • 56004

    会员

赶快注册账号,推广您的网站吧!
文章分类
热门网站
最新入驻APP小程序

宝贝市场2023-02-08

宝贝市场——买手和卖家商品展示

夺宝助手2023-02-08

夺宝助手小程序,查看每日快夺宝平

查诚信2023-02-08

查诚信是一款免费的商业查询工具

车价天天报2023-02-08

快速连接汽车销售,获知汽车最新报

考勤助理小程序2023-02-08

上班签到考勤,实时定位,后台轻松

汽车报价大全查询2023-02-08

汽车报价大全查询提供最新汽车市