中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > 圖像替換新技術(shù):狀態(tài)域方法
location.hash實現(xiàn)跨域iframe自適應(yīng) 回到列表 CSS3新特性一覽
 圖像替換新技術(shù):狀態(tài)域方法

作者:dishuipiaoxiang 時間: 2009-08-05 文檔類型:翻譯 來自:藍(lán)色理想

第 1 頁 圖像替換新技術(shù):狀態(tài)域方法 [1]
第 2 頁 圖像替換新技術(shù):狀態(tài)域方法 [2]

熟悉css的開發(fā)者一定知道圖像替換技術(shù),也深知它的意義,Dave Shea 曾在他的一篇文章對此做了詳細(xì)的總結(jié),參看 Dave Shea’s excellent summary ,Paul Young 在分析現(xiàn)存的所有方法的優(yōu)缺點之后,提出了一種新的方法,并將其命名為“狀態(tài)域方法”(The State Method),本文將詳細(xì)介紹該方法的原理:

現(xiàn)存方法的缺點:

  1. 容易失效,例如:圖像禁用或者替換圖像含有透明區(qū)域;
  2. 過于復(fù)雜不能迅速可靠的執(zhí)行;
  3. 通過js遍歷文檔樹,在頁面加載時出現(xiàn)的閃動不盡人意;
  4. 可能與一些瀏覽器不兼容

新的圖像替換方法:

新的圖像替換技術(shù)需要借助于js來實現(xiàn),但很容易執(zhí)行,只需要將一小段js引入到頭部即可。一旦js執(zhí)行,響應(yīng)的規(guī)則前將附加“.image-on”,只要客戶端的圖片未被禁用,規(guī)則就會生效,下面是一條應(yīng)用到h1“狀態(tài)域方法”的聲明:

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

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

第一條規(guī)則總是生效,第二條只有在image未被禁用時生效!皌ext-indent”使文字偏移于屏幕之外,“overflow:hidden”主要用來在FF下放置錨點在被點擊時其焦點偏移于屏幕之外。

第二條規(guī)則包繞在@media screen中,主要用來保證圖像替換只發(fā)生在屏幕閱讀器中,而不是在打印狀態(tài)下執(zhí)行。如果不這樣處理,頁面打印時,多數(shù)用戶將看到一個很大的空隙而不是有意義的文本。

該項技術(shù)執(zhí)行起來很快。因為文本偏移于屏幕之外,圖像可以包含透明元素,透過圖像本身,你看不到任何文本。Js執(zhí)行很快,幾乎是瞬時的,它充分利用瀏覽器本身的特性。

方法解析

“狀態(tài)域方法”是在一種假定的狀態(tài)下,快速使css規(guī)則生效的方法,其上下文背景為document,這樣避免了瀏覽器遍歷DOM樹。應(yīng)用“狀態(tài)域方法”有兩個理由:

  1. 針對用戶的反應(yīng),頁面部分內(nèi)容再格式化;
  2. 基于客戶端瀏覽器、設(shè)備、和其它狀況而附加額外的樣式。

“狀態(tài)域方法”通過使用下面的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,方法將更簡單。

“狀態(tài)域”可以通過下面的方法來切換:

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

如果“狀態(tài)域”為“on”,狀態(tài)域的名字將附加到規(guī)則的選擇器之前,下面這條規(guī)則在條件為真時會將錨點的顏色變成blue。

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

正如你所預(yù)想的那樣,狀態(tài)域圖像替代技術(shù)是通過檢查圖像是否被禁用而工作的。如果未被禁用,將激活“image-on”狀態(tài)域,這很直接了當(dāng)。

出處:藍(lán)色理想
責(zé)任編輯:bluehearts

上一頁 下一頁 圖像替換新技術(shù):狀態(tài)域方法 [2]

◎進入論壇網(wǎng)頁制作、WEB標(biāo)準(zhǔn)化版塊參加討論,我還想發(fā)表評論

相關(guān)文章 更多相關(guān)鏈接
CSS.JS文件發(fā)布機制的思考
使用css給圖片添加陰影入門篇
面向?qū)ο蟮腃SS
Web開發(fā)的改良
九宮格應(yīng)用案例:極酷網(wǎng)頁播放器
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標(biāo)準(zhǔn) 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標(biāo)志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標(biāo)配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標(biāo)
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:1/21個記錄/頁 轉(zhuǎn)到 頁 共2個記錄

藍(lán)色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準(zhǔn)打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔(dān)一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責(zé)任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2