code:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="js/vue.js" ></script>
</head>
<body>
<!--创建一个控制区-->
<div id="app">
<input type="button" value="荡起来" @click="lang"/>
<input type="button" value="别荡" @click="stop"/>
<h4>{{msg}}</h4>
</div>
<script>
//实力例化对象
var vm=new Vue({
el:'#app',
data:{
msg:"123,荡起来~~!",
interval:null
},
methods:{
lang(){
if (this.interval!=null)return;
this.interval=setInterval(()=>{
//获取第一个字符
var start=this.msg.substring(0,1)
//获取除第一个外,剩下的字符
var end=this.msg.substring(1)
//重新拼接得到新的字符串,并赋值给this.msg
this.msg=end+start
},500)
},
stop(){
clearInterval(this.interval)
//清除定时器后,重新将interval重置为null
this.interval=null
}
}
})
</script>
</body>
</html>
effect: