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

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > 實(shí)時(shí)切換CSS樣式
用css制作撲克牌 回到列表 給表格加滾動條
 實(shí)時(shí)切換CSS樣式

作者:sharkui 時(shí)間: 2006-01-19 文檔類型:原創(chuàng) 來自:藍(lán)色理想

用W3C標(biāo)準(zhǔn)建造的網(wǎng)站,從理論上來說可以做到完全的表現(xiàn)與結(jié)構(gòu)相分離。打個比方,就是可以在不動骨架(結(jié)構(gòu),XHMTL)和肌肉(行為,Javascript)的前提下,徹徹底底地?fù)Q一身皮(表現(xiàn),CSS)。

當(dāng)然,換皮之前你需要先按W3C標(biāo)準(zhǔn)建好你的網(wǎng)站,并且為它準(zhǔn)備兩套表現(xiàn)不一樣的CSS!皳Q皮”實(shí)質(zhì)上就是“換CSS”,我們要做的,只是用某種方法讓瀏覽器載入另一套CSS,重新渲染頁面。方法有很多種,我就介紹最常見的三種。

方法一:什么也不干

啊?什么也不干?嗯,這個……準(zhǔn)確地說是:就干那么一丁點(diǎn)兒 (你還真以為有這么好的事兒呀……)。

假設(shè)我們有兩套CSS,分別封閉在兩個不同的文件中:a.css和b.css。然后在<head>和</head>之間加入如下兩行XHTML代碼:

<link rel="stylesheet" type="text/css"
 title="主題A" href="a.css" />

<link rel="alternate stylesheet" type="text/css"
 title="主題B" href="b.css" />

然后用你的Firefox打開這個頁面,在菜單欄中選擇:查看 -> 頁面風(fēng)格,應(yīng)該可以看到如下的“風(fēng)景”:

就這么簡單,現(xiàn)在你就可以用Firefox來“換皮”了。IE?IE沒這個功能……MS就是這么拽,W3C“明文推薦”:要求瀏覽器提供給用戶自己選擇樣式表的權(quán)力,可它就不這么干。幸運(yùn)的是這件事也不是太難雜,咱就代勞一下吧。

方法二:Javascript

在方法一的基礎(chǔ)上,可以用Javascript的DOM方法訪問link對象,再將不需要的CSS設(shè)為“禁用(disabled)”,剩下的CSS就會被瀏覽器用來渲染頁面。腳本如下,請注意其中的注釋:

<script type="text/javascript">
function setStyle(title) {

  //預(yù)定義變量
  var i, links;

  //用DOM方法獲得所有的link元素
  links = document.getElementsByTagName("link");
 
  for(i=0; links[i]; i++) {

    //判斷此link元素的rel屬性中是否有style關(guān)鍵字
    //即此link元素是否為樣式表link
    //同時(shí)判斷此link元素是否含有title屬性
    if(links[i].getAttribute("rel").indexOf("style") != -1
  && links[i].getAttribute("title")) {

      //先不管三七二十一把它設(shè)為disabled
      links[i].disabled = true;

      //再判斷它的title中是否有我們指定的關(guān)鍵字
      if(links[i].getAttribute("title").indexOf(title) != -1)

        //如果有則將其激活
        links[i].disabled = false;
    }
  }
}
</script>

然后在合適的地方調(diào)用這個函數(shù),以本頁為例,添加如下兩個按鈕:

<input type="button" value="清光" onclick="setStyle('清光');" /><input type="button" value="冥焰" onclick="setStyle('冥焰');" />  

使用Javascript的好處是方便、快捷、簡單,缺點(diǎn)也是很明顯的:很難做到全站的CSS切換,只能局限在當(dāng)前頁上。為了記憶用戶的選擇,可行的方案就是采用cookie?墒蔷退闶褂胏ookie,也需要在何時(shí)載入CSS,用戶沒有Javasciprt支持怎么辦等問題上多做好些文章。所以不如用下面的方法——

方法三:服務(wù)器端腳本

毫無疑問,最好的CSS切換器應(yīng)該使用服務(wù)器端腳本(PHP、ASP、JSP等)來開發(fā)。這樣做的好處是很明顯的:直接、高效、兼容性好、可以記憶用戶選擇、甚至可以組合不同的CSS實(shí)現(xiàn)相當(dāng)復(fù)雜的“皮膚”切換。

我這里就用PHP為例,用其他的語言也都大同小異,對一般的開發(fā)人員來說不會有任何困難。

基本思路是這樣:用戶選擇一種“皮膚”,把用戶的選擇記入cookie(記入數(shù)據(jù)庫也一樣,不過這樣系統(tǒng)開銷會大一些),用戶訪問網(wǎng)站上的任何一個頁面時(shí),再從cookie(或數(shù)據(jù)庫)中讀出之前用戶的選擇,載入相應(yīng)的CSS文件(這里還是以方法一中講到的a.css和b.css為例)。

創(chuàng)建一個名為switcher.php的文件,內(nèi)容如下:

<?php$style = $_GET["style"];setcookie('style',$style,time()+31536000,'/','.site.com','0');header("location:".$_SERVER['HTTP_REFERER']);?> 

這段腳本先讀取query數(shù)據(jù),然后把參數(shù)style的值記入cookie,最后返回上一頁。接下來我們就可以創(chuàng)建兩個用于切換樣式的鏈接了,并且放在合適的頁面上,比如首頁或用戶管理后臺(注意把其中的site.com換成你的域名):

<a href="switcher.php?style=a">主題A</a>
<a href="switcher.php?style=b">主題B</a>
  

點(diǎn)擊任意一個鏈接,相應(yīng)的就會把“a”或“b”記入cookie,然后就需要一段腳本來讀取這個cookie值并且輸出XHTML來引入對應(yīng)的CSS:

<?php if(isset($_COOKIE["style"])){  $style = $_COOKIE["style"]; }else{  $style = "a";//默認(rèn)采用主題A }?>
<link rel="stylesheet" type="text/css"
 title="當(dāng)前選擇的主題" href="<?php echo $style ?>.css" />

每一個需要切換樣式的頁面都要加上這段代碼,所以直接把它加入網(wǎng)站的頭文件中就行了。當(dāng)然你可以根據(jù)自己的需要修改這個腳本,但萬變不離其宗,總的思路應(yīng)該是不變的。

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

◎進(jìn)入論壇網(wǎng)頁制作、網(wǎng)站綜合版塊參加討論

相關(guān)文章 更多相關(guān)鏈接
用css制作撲克牌
建立自己的操作標(biāo)準(zhǔn)
用GoLive實(shí)現(xiàn)CSS+DIV之二
[xml] xml ,xsl,css 之亂搞
用GoLive實(shí)現(xiàn)CSS+DIV之一
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計(jì)比賽 網(wǎng)頁制作 web標(biāo)準(zhǔn) 用戶體驗(yàn) UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點(diǎn)最新 站點(diǎn)最新列表
周大!熬•自然”設(shè)計(jì)大賽開啟
國際體驗(yàn)設(shè)計(jì)大會7月將在京舉行
中國國防科技信息中心標(biāo)志征集
云計(jì)算如何讓安全問題可控
云計(jì)算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機(jī)會
阿里行云
云手機(jī)年終巨獻(xiàn),送禮標(biāo)配299起
阿里巴巴CTO王堅(jiān)的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機(jī)主題設(shè)計(jì)大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標(biāo)
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機(jī)制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項(xiàng)目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule

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

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

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

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

雜⑦雜⑧ Gold NORMANA V2