我使用jquery-style-switcher.js
来改变某些元素的样式。当我点击页面的颜色样式时没有更改,并且在此页面的源代码中将此类jssError error level0
添加到包含颜色的ul
标记。此代码在HTML页面中工作,但在CMS中没有!
我通过chrome调试这个js文件,并了解当一般html文件中的这个js文件失败时:一个事件称之为 addClickEvents 已执行但在我的网站中使用此模板的网站皮肤: addClickEvents 功能未执行。调用addClickEvents的函数是 init 函数
init: function ($root, config) {
this.$root = $root;
this.config = config ? config : {};
this.setDefaultTheme();
if(this.defaultTheme) {
// try cookies
if (this.config.cookie) {
this.checkCookie();
}
// try hover
if (this.config.hasPreview) {
this.addHoverEvents();
}
// finally, add click events
this.addClickEvents();
} else {
this.$root.addClass('jssError error level0');
}
}
在此函数(init)中: defaultTheme值未定义!!!!
为什么defaultTheme未定义?如果你能回答这个问题,问题就会解决。
jquery-style-switcher.js:
(function ($) {
var jStyleSwitcher,
_defaultOptions = {
hasPreview: true,
defaultThemeId: 'jssDefault',
fullPath: 'css/',
cookie: {
expires: 30,
isManagingLoad: true
}
},
// private
_cookieKey = 'jss_selected',
_docCookies = {};
/*\
|*|
|*| :: cookies.js ::
|*|
|*| A complete cookies reader/writer framework with full unicode support.
|*|
|*| revision #1
|*|
|*| https://developer.mozilla.org/en-US/docs/Web/API/document.cookie
|*|
|*| This framework is released under the GNU Public License, version 3 or later.
|*| http://www.gnu.org/licenses/gpl-3.0-standalone.html
|*|
|*| Syntaxes:
|*|
|*| * docCookies.setItem(name, value[, end[, path[, domain[, secure]]]])
|*| * docCookies.getItem(name)
|*| * docCookies.removeItem(name[, path[, domain]])
|*| * docCookies.hasItem(name)
|*| * docCookies.keys()
|*|
\*/
_docCookies = {
getItem: function (sKey) {
if (!sKey) {
return null;
}
return decodeURIComponent(document.cookie.replace(new RegExp("(?:(?:^|.*;)\\s*" + encodeURIComponent(sKey).replace(/[\-\.\+\*]/g, "\\$&") + "\\s*\\=\\s*([^;]*).*$)|^.*$"), "$1")) || null;
},
setItem: function (sKey, sValue, vEnd, sPath, sDomain, bSecure) {
if (!sKey || /^(?:expires|max\-age|path|domain|secure)$/i.test(sKey)) {
return false;
}
var sExpires = "";
if (vEnd) {
switch (vEnd.constructor) {
case Number:
sExpires = vEnd === Infinity ? "; expires=Fri, 31 Dec 9999 23:59:59 GMT" : "; max-age=" + vEnd;
break;
case String:
sExpires = "; expires=" + vEnd;
break;
case Date:
sExpires = "; expires=" + vEnd.toUTCString();
break;
}
}
document.cookie = encodeURIComponent(sKey) + "=" + encodeURIComponent(sValue) + sExpires + (sDomain ? "; domain=" + sDomain : "") + (sPath ? "; path=" + sPath : "") + (bSecure ? "; secure" : "");
return true;
},
removeItem: function (sKey, sPath, sDomain) {
if (!this.hasItem(sKey)) {
return false;
}
document.cookie = encodeURIComponent(sKey) + "=; expires=Thu, 01 Jan 1970 00:00:00 GMT" + (sDomain ? "; domain=" + sDomain : "") + (sPath ? "; path=" + sPath : "");
return true;
},
hasItem: function (sKey) {
if (!sKey) {
return false;
}
return (new RegExp("(?:^|;\\s*)" + encodeURIComponent(sKey).replace(/[\-\.\+\*]/g, "\\$&") + "\\s*\\=")).test(document.cookie);
},
keys: function () {
var aKeys = document.cookie.replace(/((?:^|\s*;)[^\=]+)(?=;|$)|^\s*|\s*(?:\=[^;]*)?(?:\1|$)/g, "").split(/\s*(?:\=[^;]*)?;\s*/);
for (var nLen = aKeys.length, nIdx = 0; nIdx < nLen; nIdx++) {
aKeys[nIdx] = decodeURIComponent(aKeys[nIdx]);
}
return aKeys;
}
};
jStyleSwitcher = function ($root, config) {
return this.init($root, config);
};
jStyleSwitcher.prototype = {
/**
* {Object} DOM reference to style option list
*/
$root: null,
/**
* {Object} configs for the style switcher
*/
config: {},
/**
* {Object} jQuery reference to <link> tag for swapping CSS
*/
$themeCss: null,
/**
* {String} default theme page was loaded with
*/
defaultTheme: null,
init: function ($root, config) {
this.$root = $root;
this.config = config ? config : {};
this.setDefaultTheme();
if(this.defaultTheme) {
// try cookies
if (this.config.cookie) {
this.checkCookie();
}
// try hover
if (this.config.hasPreview) {
this.addHoverEvents();
}
// finally, add click events
this.addClickEvents();
} else {
this.$root.addClass('jssError error level0');
}
},
setDefaultTheme: function () {
this.$themeCss = $('link[id=' + this.config.defaultThemeId + ']');
if(this.$themeCss.length) {
this.defaultTheme = this.$themeCss.attr('href');
}
},
resetStyle: function() {
this.updateStyle(this.defaultTheme);
},
updateStyle: function(newStyle) {
this.$themeCss.attr('href', newStyle);
},
getFullAssetPath: function(asset) {
return this.config.fullPath + asset + '.css';
},
checkCookie: function () {
var styleCookie;
// if using cookies and using JavaScript to load css
if (this.config.cookie && this.config.cookie.isManagingLoad) {
// check if css is set in cookie
styleCookie = _docCookies.getItem(_cookieKey);
if (styleCookie) {
newStyle = this.getFullAssetPath(styleCookie);
// update link tag
this.updateStyle(newStyle);
// update default ref
this.defaultTheme = newStyle;
}
}
},
addHoverEvents: function () {
var self = this;
this.$root.find('a').hover(
function () {
var asset = $(this).data('theme'),
newStyle = self.getFullAssetPath(asset);
// update link tag
self.updateStyle(newStyle);
},
function () {
// reset link tag
self.resetStyle();
}
);
},
addClickEvents: function () {
var self = this;
this.$root.find('a').click(
function () {
var asset = $(this).data('theme'),
newStyle = self.getFullAssetPath(asset);
// update link tag
self.updateStyle(newStyle);
// update default ref
self.defaultTheme = newStyle;
// try to store cookie
if (self.config.cookie) {
_docCookies.setItem(_cookieKey, asset, self.config.cookie.expires, '/');
}
}
);
}
};
$.fn.styleSwitcher = function (options) {
return new jStyleSwitcher(this, $.extend(true, _defaultOptions, options));
};
})(jQuery);
我页面中此部分的HTML:
<div id="colour-variations">
<a class="option-toggle"><i class="icon-gear"></i></a>
<h3>Preset Colors</h3>
<ul class="jssError error level0">
<li><a href="javascript: void(0);" data-theme="style"></a></li>
<li><a href="javascript: void(0);" data-theme="pink"></a></li>
<li><a href="javascript: void(0);" data-theme="blue"></a></li>
<li><a href="javascript: void(0);" data-theme="turquoise"></a></li>
<li><a href="javascript: void(0);" data-theme="orange"></a></li>
<li><a href="javascript: void(0);" data-theme="lightblue"></a></li>
<li><a href="javascript: void(0);" data-theme="brown"></a></li>
<li><a href="javascript: void(0);" data-theme="green"></a></li>
</ul>
</div>
您可以看到template这是一般网站。我在dotnetnuke7
的皮肤中使用此模板,出现了这个问题。
答案 0 :(得分:1)
你几乎已经成功了,只需要解决一些问题。
这些步骤适用于您的&#34;下载我的代码&#34;档案
首先,在处理单击颜色主题方形图标时,您的代码会抛出此JS错误:
// Check Text box From & To Date between First Half
if (firstHalfFrom >= txtFromDate || txtFromDate <= firstHalfTo) {
firstHalfFromDate = MyDateFormatter(new Date(txtFromDate)); // First Half From Date
if (firstHalfTo >= txtToDate || txtToDate <= firstHalfFrom) { // First Half To Date
firstHalfToDate = MyDateFormatter(new Date(txtToDate));
} else {
firstHalfToDate = MyDateFormatter(new Date(firstHalfTo));
}
} else {
firstHalfFromDate = "";
firstHalfToDate = "";
}
// Check Text box From & To Date between Second Half
if (secondHalfTo <= txtToDate || txtToDate >= secondHalfFrom) {
secondHalfToDate = MyDateFormatter(new Date(txtToDate)); // Second Half To Date
if (secondHalfFrom <= txtFromDate || txtFromDate >= secondHalfTo) { // Second Half From Date
secondHalfFromDate = MyDateFormatter(new Date(txtFromDate));
} else {
secondHalfFromDate = MyDateFormatter(new Date(secondHalfFrom));
}
} else {
secondHalfFromDate = "";
secondHalfToDate = "";
}
在Uncaught TypeError: Cannot read property 'top' of undefined
中,更改main.js
功能。在必须定义clickMenu
的条件下给$('html, body').animate
打电话。
section
其次,在var clickMenu = function() {
$('a:not([class="external"])').click(function(event){
var section = $(this).data('nav-section'),
navbar = $('#navbar');
if(section){ // <- this wrap condition
$('html, body').animate({
scrollTop: $('[data-section="' + section + '"]').offset().top
}, 2000);
}
if ( navbar.is(':visible')) {
navbar.removeClass('in');
navbar.attr('aria-expanded', 'false');
$('.js-fh5co-nav-toggle').removeClass('active');
}
event.preventDefault();
return false;
});
};
,第799行,您switcher.html
"jssError error level0"
元素内ul
上的#colour-variations
课程已离开(<}} >
<ul class="jssError error level0">
...
</ul>
所以删除这些类:
<ul>
...
</ul>
最后一件小事:在<link>
的某处添加<head>
:
<link type="text/css" rel="stylesheet" id="theme-switch" href="style.css">
插件需要正确初始化。缺少这一行是导致"jssError error level0"
错误的原因。
我也做了.zip with working code。希望它有所帮助!
答案 1 :(得分:0)
如果您想将其添加到活动中,您也可以轻松添加。
$(".first").click(function() {
$(this).addClass("second");
});
答案 2 :(得分:0)
这是setDefaultTheme()
函数
this.$themeCss = $('link[id=' + this.config.defaultThemeId + ']');
if(this.$themeCss.length) {
this.defaultTheme = this.$themeCss.attr('href');
}
这是设置defaultThemeId
的地方
_defaultOptions = {
hasPreview: true,
defaultThemeId: 'jssDefault',
fullPath: 'css/',
cookie: {
expires: 30,
isManagingLoad: true
}
},
您在head
上需要添加类似
<link id="jssDefault" href="{your default theme here}" />
因此它可以正确设置您的默认主题。