具有 onclick 功能的自定义复选框在实际切换复选框之前执行功能
Custom checkbox with onclick functionality executes function before checkbox is actually toggled
问题:
我有一组自定义复选框,显示为滑动 on/off-buttons。这些按钮切换其他元素的可见性。到目前为止,我一直使用带有 onclick 功能的常规复选框,它会检查所有设置并更新元素的可见性。它工作得很好,但是在制作滑动按钮并将 onclick 函数移动到相应的复选框标签之后,我的可见性更新被延迟了一次。在实际选中复选框之前执行可见性更新。
问题:
如何更改执行顺序,以便我的可见性更新在复选框被切换后执行?
附加信息:
在我开发的早期,我使用了一个 onchange-listener 复选框,但没有成功。在我的完整系统中,我还实现了按钮,用于一次选中和取消选中所有复选框,onchange-listener 将迭代我的可见性更新 18 次。每个复选框一次。花了太多时间。此外,除了避免使用等待之外,我还想避免摆脱按钮的动画效果。
我在这个 jsfiddle 中重现了错误:http://jsfiddle.net/9n81ff1b/24/
对于双倍 javascript 功能,我深表歉意。我很难让我的 js 在 jsfiddle 中工作,这是快速而肮脏的解决方案。我的实际项目中没有双重功能:
HTML:
<div class="onoffswitch">
<input type="checkbox" name="categorycheckbox" value="A" class="onoffswitch-checkbox" id="c1">
<label class="onoffswitch-label" for="c1" onclick="updateSection()">
<div class="onoffswitch-inner">
<div class="onoffswitch-active"><div class="onoffswitch-switch"></div></div>
<div class="onoffswitch-inactive"><div class="onoffswitch-switch"></div></div>
</div>
</label>
</div>
<div class="onoffswitch">
<input type="checkbox" name="categorycheckbox" value="B" class="onoffswitch-checkbox" id="c2">
<label class="onoffswitch-label" for="c2" onclick="updateSection()">
<div class="onoffswitch-inner">
<div class="onoffswitch-active"><div class="onoffswitch-switch"></div></div>
<div class="onoffswitch-inactive"><div class="onoffswitch-switch"></div></div>
</div>
</label>
</div>
<div class="onoffswitch">
<input type="checkbox" name="categorycheckbox" value="C" class="onoffswitch-checkbox" id="c3">
<label class="onoffswitch-label" for="c3" onclick="updateSection()">
<div class="onoffswitch-inner">
<div class="onoffswitch-active"><div class="onoffswitch-switch"></div></div>
<div class="onoffswitch-inactive"><div class="onoffswitch-switch"></div></div>
</div>
</label>
</div>
<div class="colorbox A"> 1</div>
<div class="colorbox B"> 2</div>
<div class="colorbox C"> 3</div>
JS:(没有加倍功能)
$(document).ready(function(){
updateSection();
});
function updateSection(){
console.log("updatingSection");
categories = [];
$('input[name=categorycheckbox]').each(function() {
if (this.checked) {
categories.push(this.value);
}
});
$('.colorbox').each(function(index, element) {
var visible = true;
var currentElement = element;
if (!hasClassOfArray(currentElement, categories)){
visible = false;
};
$(currentElement).toggle(visible);
});
}
function hasClassOfArray(element, classes) {
for (var i = 0, j = classes.length; i < j; i++) {
if (hasClass(element, classes[i])) {
return true;
}
}
return false;
}
function hasClass(element, cls) {
return (' ' + element.className + ' ').indexOf(' ' + cls + ' ') > -1;
}
CSS:
.onoffswitch {
position: relative; width: 90px;
-webkit-user-select:none; -moz-user-select:none; -ms-user-select: none;
}
.onoffswitch-checkbox {
display: none;
}
.onoffswitch-label {
display: block; overflow: hidden; cursor: pointer;
border: 2px solid #999999; border-radius: 20px;
}
.onoffswitch-inner {
display: block; width: 200%; margin-left: -100%;
-moz-transition: margin 0.3s ease-in 0s; -webkit-transition: margin 0.3s ease-in 0s;
-o-transition: margin 0.3s ease-in 0s; transition: margin 0.3s ease-in 0s;
}
.onoffswitch-inner:before, .onoffswitch-inner:after {
display: block; float: left; width: 50%; height: 30px; padding: 0; line-height: 30px;
font-size: 14px; color: white; font-family: Trebuchet, Arial, sans-serif; font-weight: bold;
-moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box;
}
.onoffswitch-inner:before {
content: "ON";
padding-left: 10px;
background-color: #34C134; color: #FFFFFF;
}
.onoffswitch-inner:after {
content: "OFF";
padding-right: 10px;
background-color: #E3E3E3; color: #999999;
text-align: right;
}
.onoffswitch-switch {
display: block; width: 18px; margin: 6px;
background: #FFFFFF;
border: 2px solid #999999; border-radius: 20px;
position: absolute; top: 0; bottom: 0; right: 56px;
-moz-transition: all 0.3s ease-in 0s; -webkit-transition: all 0.3s ease-in 0s;
-o-transition: all 0.3s ease-in 0s; transition: all 0.3s ease-in 0s;
}
.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-inner {
margin-left: 0;
}
.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-switch {
right: 0px;
}
.colorbox{
height: 64px;
width: 64px;
}
.A{
background: yellow;
}
.B{
background: green;
}
.C{
background: red;
}
不使用标签的 onclick
事件,而是使用输入元素的 onchange
事件
<input type="checkbox" name="categorycheckbox" value="A" class="onoffswitch-checkbox" id="c1" onchange="updateSection()">
http://jsfiddle.net/9n81ff1b/27/
因为一旦您单击标签,您的脚本就会在输入实际更改之前运行。使用输入元素 onchange
事件可以解决该问题
仅仅将 onclick 属性转移到复选框本身,而不是它们的标签,就解决了这个问题。
问题:
我有一组自定义复选框,显示为滑动 on/off-buttons。这些按钮切换其他元素的可见性。到目前为止,我一直使用带有 onclick 功能的常规复选框,它会检查所有设置并更新元素的可见性。它工作得很好,但是在制作滑动按钮并将 onclick 函数移动到相应的复选框标签之后,我的可见性更新被延迟了一次。在实际选中复选框之前执行可见性更新。
问题: 如何更改执行顺序,以便我的可见性更新在复选框被切换后执行?
附加信息: 在我开发的早期,我使用了一个 onchange-listener 复选框,但没有成功。在我的完整系统中,我还实现了按钮,用于一次选中和取消选中所有复选框,onchange-listener 将迭代我的可见性更新 18 次。每个复选框一次。花了太多时间。此外,除了避免使用等待之外,我还想避免摆脱按钮的动画效果。
我在这个 jsfiddle 中重现了错误:http://jsfiddle.net/9n81ff1b/24/
对于双倍 javascript 功能,我深表歉意。我很难让我的 js 在 jsfiddle 中工作,这是快速而肮脏的解决方案。我的实际项目中没有双重功能:
HTML:
<div class="onoffswitch">
<input type="checkbox" name="categorycheckbox" value="A" class="onoffswitch-checkbox" id="c1">
<label class="onoffswitch-label" for="c1" onclick="updateSection()">
<div class="onoffswitch-inner">
<div class="onoffswitch-active"><div class="onoffswitch-switch"></div></div>
<div class="onoffswitch-inactive"><div class="onoffswitch-switch"></div></div>
</div>
</label>
</div>
<div class="onoffswitch">
<input type="checkbox" name="categorycheckbox" value="B" class="onoffswitch-checkbox" id="c2">
<label class="onoffswitch-label" for="c2" onclick="updateSection()">
<div class="onoffswitch-inner">
<div class="onoffswitch-active"><div class="onoffswitch-switch"></div></div>
<div class="onoffswitch-inactive"><div class="onoffswitch-switch"></div></div>
</div>
</label>
</div>
<div class="onoffswitch">
<input type="checkbox" name="categorycheckbox" value="C" class="onoffswitch-checkbox" id="c3">
<label class="onoffswitch-label" for="c3" onclick="updateSection()">
<div class="onoffswitch-inner">
<div class="onoffswitch-active"><div class="onoffswitch-switch"></div></div>
<div class="onoffswitch-inactive"><div class="onoffswitch-switch"></div></div>
</div>
</label>
</div>
<div class="colorbox A"> 1</div>
<div class="colorbox B"> 2</div>
<div class="colorbox C"> 3</div>
JS:(没有加倍功能)
$(document).ready(function(){
updateSection();
});
function updateSection(){
console.log("updatingSection");
categories = [];
$('input[name=categorycheckbox]').each(function() {
if (this.checked) {
categories.push(this.value);
}
});
$('.colorbox').each(function(index, element) {
var visible = true;
var currentElement = element;
if (!hasClassOfArray(currentElement, categories)){
visible = false;
};
$(currentElement).toggle(visible);
});
}
function hasClassOfArray(element, classes) {
for (var i = 0, j = classes.length; i < j; i++) {
if (hasClass(element, classes[i])) {
return true;
}
}
return false;
}
function hasClass(element, cls) {
return (' ' + element.className + ' ').indexOf(' ' + cls + ' ') > -1;
}
CSS:
.onoffswitch {
position: relative; width: 90px;
-webkit-user-select:none; -moz-user-select:none; -ms-user-select: none;
}
.onoffswitch-checkbox {
display: none;
}
.onoffswitch-label {
display: block; overflow: hidden; cursor: pointer;
border: 2px solid #999999; border-radius: 20px;
}
.onoffswitch-inner {
display: block; width: 200%; margin-left: -100%;
-moz-transition: margin 0.3s ease-in 0s; -webkit-transition: margin 0.3s ease-in 0s;
-o-transition: margin 0.3s ease-in 0s; transition: margin 0.3s ease-in 0s;
}
.onoffswitch-inner:before, .onoffswitch-inner:after {
display: block; float: left; width: 50%; height: 30px; padding: 0; line-height: 30px;
font-size: 14px; color: white; font-family: Trebuchet, Arial, sans-serif; font-weight: bold;
-moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box;
}
.onoffswitch-inner:before {
content: "ON";
padding-left: 10px;
background-color: #34C134; color: #FFFFFF;
}
.onoffswitch-inner:after {
content: "OFF";
padding-right: 10px;
background-color: #E3E3E3; color: #999999;
text-align: right;
}
.onoffswitch-switch {
display: block; width: 18px; margin: 6px;
background: #FFFFFF;
border: 2px solid #999999; border-radius: 20px;
position: absolute; top: 0; bottom: 0; right: 56px;
-moz-transition: all 0.3s ease-in 0s; -webkit-transition: all 0.3s ease-in 0s;
-o-transition: all 0.3s ease-in 0s; transition: all 0.3s ease-in 0s;
}
.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-inner {
margin-left: 0;
}
.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-switch {
right: 0px;
}
.colorbox{
height: 64px;
width: 64px;
}
.A{
background: yellow;
}
.B{
background: green;
}
.C{
background: red;
}
不使用标签的 onclick
事件,而是使用输入元素的 onchange
事件
<input type="checkbox" name="categorycheckbox" value="A" class="onoffswitch-checkbox" id="c1" onchange="updateSection()">
http://jsfiddle.net/9n81ff1b/27/
因为一旦您单击标签,您的脚本就会在输入实际更改之前运行。使用输入元素 onchange
事件可以解决该问题
仅仅将 onclick 属性转移到复选框本身,而不是它们的标签,就解决了这个问题。