如下是网上摘录的:
-------START----------------------
注:引入JS的顺序jquery>cookie>easyuicss>changeEasyUITheme.js
首先将easyui的样式文件加入一个ID,这里命名为easyuiTheme,然后在样式文件下面加入一个JS文件
<script type="text/javascript" charset="UTF-8" src="jslib/jquery-easyui-1.2.5/jquery-1.7.1.min.js"></script> <script type="text/javascript" charset="UTF-8" src="jslib/jquery.cookie.js"></script> <link id="easyuiTheme" rel="stylesheet" type="text/css" href="jslib/jquery-easyui-1.2.5/themes/gray/easyui.css"> <script type="text/javascript" charset="UTF-8" src="jslib/changeEasyuiTheme.js"></script> <link rel="stylesheet" type="text/css" href="jslib/jquery-easyui-1.2.5/themes/icon.css"> <script type="text/javascript" charset="UTF-8" src="jslib/jquery-easyui-1.2.5/jquery.easyui.min.js"></script> <script type="text/javascript" charset="UTF-8" src="jslib/jquery-easyui-1.2.5/locale/easyui-lang-zh_CN.js"></script>
changeEasyuiTheme.js文件的内容是
function changeThemeFun(themeName) {/* 更换主题 */ var $easyuiTheme = $('#easyuiTheme'); var url = $easyuiTheme.attr('href'); var href = url.substring(0, url.indexOf('themes')) + 'themes/' + themeName + '/easyui.css'; $easyuiTheme.attr('href', href); var $iframe = $('iframe'); if ($iframe.length > 0) { for ( var i = 0; i < $iframe.length; i++) { var ifr = $iframe[i]; $(ifr).contents().find('#easyuiTheme').attr('href', href); } } $.cookie('easyuiThemeName', themeName, { expires : 7 }); }; if ($.cookie('easyuiThemeName')) { changeThemeFun($.cookie('easyuiThemeName')); }
jquery.cookie.js的内容是
jQuery.cookie = function (key, value, options) { // key and value given, set cookie... if (arguments.length > 1 && (value === null || typeof value !== "object")) { options = jQuery.extend({}, options); if (value === null) { options.expires = -1; } if (typeof options.expires === 'number') { var days = options.expires, t = options.expires = new Date(); t.setDate(t.getDate() + days); } return (document.cookie = [ encodeURIComponent(key), '=', options.raw ? String(value) : encodeURIComponent(String(value)), options.expires ? '; expires=' + options.expires.toUTCString() : '', // use expires attribute, max-age is not supported by IE options.path ? '; path=' + options.path : '', options.domain ? '; domain=' + options.domain : '', options.secure ? '; secure' : '' ].join('')); } // key and possibly options given, get cookie... options = value || {}; var result, decode = options.raw ? function (s) { return s; } : decodeURIComponent; return (result = new RegExp('(?:^|; )' + encodeURIComponent(key) + '=([^;]*)').exec(document.cookie)) ? decode(result[1]) : null; };
使用的时候
changeThemeFun('default'); changeThemeFun('gray');
-----END-----------
但是,问题来了。整个框架在首页的时候可以根据cookie中的 $.cookie('easyuiThemeName') 获取到指,但是其他子页面却无法获取。
接着找资料,原来是cookie的作用域问题。
cookie的一个属性:Path – 路径。指定与cookie关联的WEB页。值可以是一个目录,或者是一个路径。如果http://www.baidu.com/a/index.html 建立了一个cookie,如果不设置cookie的path值,那么默认在http://www.baidu.com/a/目录里的所有页面,以及该目录下面任何子目录里的页面都可以访问这个 cookie。但是在http://www.baidu.com/b目录下无法访问到这个cookie。这时,我们要把cookies的path属性设置成“/”。在指定路径的时候,凡是来自同一服务器,URL里有相同路径的所有WEB页面都可以共享cookies。
上面的问题解决办法:
$.cookie('easyuiThemeName', themeName, { expires : 7 , path:"/" });
注:,path:"/" 为增加部分
思维拓展:
如果我们想让 blog.baidu.com 能够访问bbs.baidu.com设置的cookies,该怎么办?
但是有个问题来了,不能把cookies域属性设置成与设置它的服务器的所在域不同的值。
介绍另一个cookie的属性 :Domain – 域。指定关联的WEB服务器或域。值是域名,比如baidu.com。这是对path路径属性的一个延伸。 我们可以把domain属性设置成“baidu.com”,并把path属性设置成“/”。