$('#element').toggle(function(){
$(this).addClass('one');
},
function(){
$(this).removeClass('one').addClass('two');
},
function(){
$(this).removeClass('two').addClass('three');
});
#element{
width: 150px;
height: 150px;
border: 1px solid #000;
}
.one{
background: orange;
}
.two{
background: blue;
}
.three{
background: red;
}
<script src="https://code.jquery.com/jquery-3.1.1.js"></script>
<div id="element"></div>
嗨,我正试图开发用户界面的基础上,三次点击同一个ID,这是我正在尝试的代码。但是当我渲染它时,我得到的错误是
`Uncaught TypeError: r.easing[this.easing] is not a function
at init.run (jquery-3.1.1.min.js:3)
at i (jquery-3.1.1.min.js:3)
at Function.r.fx.timer (jquery-3.1.1.min.js:3)
at hb (jquery-3.1.1.min.js:3)
at HTMLDivElement.g (jquery-3.1.1.min.js:3)
at Function.dequeue (jquery-3.1.1.min.js:3)
at HTMLDivElement.<anonymous> (jquery-3.1.1.min.js:3)
at Function.each (jquery-3.1.1.min.js:2)
at r.fn.init.each (jquery-3.1.1.min.js:2)
at r.fn.init.queue (jquery-3.1.1.min.js:3)`
有人能帮我解决这个问题吗?我搜索了一下,但力没有找到解决办法。
谢谢。
卡丁
最佳答案
只需将jquery替换为:
var flag = 0, existing_class = '';
var class_value = ['one', 'two', 'three'];
$('#element').click(function(){
if(flag <= 2)
{
$(this).removeClass(existing_class);
$(this).addClass(class_value[flag]);
existing_class = class_value[flag];
}
flag++;
});
或
如果要调用重复的“one”、“two”、“three”类,则应尝试以下代码:
var flag = 1, existing_class = '';
var class_value = {1 : 'one', 2 : 'two', 3 : 'three'};
$('#element').click(function(){
$(this).removeClass(existing_class);
if(flag > 3) {
$(this).addClass(class_value[flag % 3 === 0 ? 3 : flag % 3]);
existing_class = class_value[flag % 3 === 0 ? 3 : flag % 3];
} else {
$(this).addClass(class_value[flag]);
existing_class = class_value[flag];
}
flag++;
});