成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? jQuery無刷新切換主題皮膚實例講解
全站頭部文字 我要出現在這里
jQuery無刷新切換主題皮膚實例講解 574 2024-03-23   

主題皮膚切換功能在很多網站和系統中應用,用戶可以根據此功能設置自己喜歡的主題顏色風格,增強了用戶體驗。本文將圍繞如何使用jQuery實現點擊無刷新切換主題皮膚功能。

查看圖片

實現該功能的原理就是通過點擊定義的主題樣式,改變頁面當前引用的主題CSS文件,并且將當前的主題樣式寫入cookie中或者寫入數據庫中,以便下次該用戶重新訪問頁面時,調用的就是上次設置好的主題樣式。
準備主題皮膚樣式
首先,我準備了三個樣式表CSS文件,分別是三種風格的主題皮膚,將其引入頁面,放置在頁面的<head>之間。

<link title="default" rel="stylesheet" type="text/css"  /> 
<link title="blue" rel="stylesheet" type="text/css"  disabled="disabled" /> 
<link title="brown" rel="stylesheet" type="text/css"  disabled="disabled" /> 

注意我給每個<link>添加了title屬性,是由用處的,另外我禁用了第2個和第3個CSS文件,就是默認起作用的是第1個CSS文件。
XHTML

<ul id="styles"> 
 <li id="default">經典</li> 
 <li id="blue">淡藍</li> 
 <li id="brown">棕色</li> 
</ul> 

三種主題風格用于點擊切換,注意我分別給每個li加了id屬性。
CSS

ul#styles{margin-top:10px} 
ul#styles li{float:left; width:50px; height:40px; line-height:40px; padding:2px; 
margin-left:10px; border:1px solid #fff; text-align:center; color:#fff; cursor:pointer} 
ul#styles li.cur{border:1px solid #369; background-image:url(images/selected.gif); 
background-repeat:no-repeat; background-position:4px 32px} 
ul#styles li#default{background-color:#162934;} 
ul#styles li#blue{background-color:#90c5e7} 
ul#styles li#brown{background-color:#601f00} 

用CSS渲染XHTML,其中ul#styles li.cur是指當前主題選中下的樣式,我用一個小勾表示當前選中的主題。
jQeury
首先我們要引入jquery庫和jquery.cookie插件。jquery.cookie插件為jQuery提供了強大的cookie操作功能,你不用去寫復雜的原生的javascript,只管直接調用該插件就行。關于該插件的使用,請閱讀本站文章:

<script type="text/javascript" src="http://www.gimoo.net/t/1904/js/jquery.js"></script> 
<script type="text/javascript" src="http://www.gimoo.net/t/1904/js/jquery.cookie.js"></script> 

接下來,當用戶點擊切換選擇主題時,要發生以下動作:獲取選擇的主題(id),查看引用的CSS文件,如果發現其title屬性值正好與當前選中的主題id值相等,則應用該主題CSS文件,同時將其他引用的CSS文件禁用,并且將當前選中的主題寫入cookie中,設置cookie過期時間,最后將當前選中的主題按鈕(li)設置為當前選中狀態。具體看下面的代碼:

$("#styles li").click(function(){ 
 var style = $(this).attr("id"); 
 $("link[title='"+style+"']").removeAttr("disabled"); 
 $("link[title!='"+style+"']").attr("disabled","disabled"); 
 $.cookie("mystyle",style,{expires:30}); 
 $(this).addClass("cur").siblings().removeClass("cur"); 
}); 

注意,在本例中我將選中的樣式保存在用戶cookie中,cookie名稱為”mystyle“,值為當前選中的主題值,過去時間為30天,即:expires:30
接著需要做的是頁面載入時,讀取主題cookie值,如果主題cookie存在則調用cookie值對應的主題樣式CSS文件,并且設置當前主題按鈕狀態為選中狀態,反之,則調用默認樣式。代碼如下:

var cookie_style = $.cookie("mystyle"); 
if(cookie_style==null){ 
 $("link[title='default']").removeAttr("disabled"); 
 $("#styles li#default").addClass("cur"); 
}else{ 
 $("link[title='"+cookie_style+"']").removeAttr("disabled"); 
 $("#styles li[id='"+cookie_style+"']").addClass("cur"); 
 $("link[title!='"+cookie_style+"']").attr("disabled","disabled"); 
} 

將以上兩段代碼加入到$(function(){})中,工作到此完成。
值得一提的是,本文應用的cookie記錄用戶所選擇設置的主題皮膚樣式,但是當cookie到期或者用戶清除了瀏覽器的COOKIE,亦或者用戶換用其他瀏覽器瀏覽時,當前設置的主題就會失效。為了讓用戶永久保存選擇的主題樣式,必須將所選的主題與用戶信息對應,并寫入數據庫,下次該用戶登錄就可以直接讀取主題,當然,該方法應用在有用戶權限范圍的系統,如后臺管理系統,個人中心等。

以上就是本文的全部內容,內容很詳細,方便讀者理解閱讀,希望大家能有所收獲吧!



主站蜘蛛池模板: 白皮书电影| 皮囊之下| 小伙捡了一沓钱完整版| 最后的朋友| 男生魔鬼训练压腿| fourteen steps课文翻译| 日韩夫妻性生活视频| 5年级上册第1单元作文我的心爱之物| 金恒| 张小波简历及个人资料简介| 唐人街探案四免费观看| 《夏日情人》| 100以内加减法题库100题可打印| 四美人| 金猴降妖 动漫| 公民的基本权利和义务教学设计| 男同视频在线| 抖音网页版| 鬼迷心窍1994| 烽火硝烟里的青春演员表| 汤唯和梁朝伟拍戏原版视频在线观看| 26uuu电影网| 太原教育电视台| 周杰伦《退后》歌词| 杨子萱| 阮经天新电影| 大太监李莲英| www.56.com| ,xx| 郭明翔| 廖凡和莫小棋主演的一半火焰一半海水 | 15j401图集电子版免费查看| 性感美女写真视频| footjob videos| 漂亮孕妇突然肚子疼视频| 色在线视频| 裸色亮片| 普庵咒全文注音版| 李柯以写真照片| 郭明翔| 美女全身透明衣服|

?。?!站長長期在線接?。?!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103