Mr.*_*ist 3 vue.js computed-properties vuejs2
我正在学习 Vue JS。我想使用setInterval. 但是不能传递Methodto的变化值Computed Property。两秒后班级将自动更改为“ changeColor”的更改值
我的代码:
HTML:
<div>
<button @click="startEffect">Start Effect</button>
<div id="effect" :class="myClass"></div>
</div>
Run Code Online (Sandbox Code Playgroud)
CSS:
.highlight {
background-color: red;
width: 200px !important;
}
.shrink {
background-color: gray;
width: 50px !important;
}
Run Code Online (Sandbox Code Playgroud)
VueJS:
new Vue({
el: '#exercise',
data: {
changeColor: false
},
methods : {
startEffect: function() {
setInterval(function(){
this.changeColor = !this.changeColor;
//alert(this.changeColor);
}, 2000);
//alert(this.changeColor);
}
},
computed: {
myClass: function() {
return {
highlight: this.changeColor,
shrink: !this.changeColor
}
}
}
})
Run Code Online (Sandbox Code Playgroud)
将您的功能绑定到组件...
setInterval(function(){
this.changeColor = !this.changeColor;
}.bind(this), 2000);
Run Code Online (Sandbox Code Playgroud)
然后你可以做...
<div id="effect" :class="[changeColor?'highlight':'shrink']"></div>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4512 次 |
| 最近记录: |