Javascript 如何在 vue 组件中使用 setInterval

声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow 原文地址: http://stackoverflow.com/questions/43335477/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me): StackOverFlow

提示:将鼠标放在中文语句上可以显示对应的英文。显示中英文
时间:2020-08-23 01:50:52  来源:igfitidea点击:

how to use setInterval in vue component

javascriptvuejs2vue-component

提问by A_Wen

I define the timer in each my-progress, used to update the value of view, but the console shows the value of the constant changes, and the value of view is still not changed, how can I do in the timer to change the value of view

我在每个my-progress中定义了timer,用来更新view的值,但是console显示的是不断变化的值,而view的值还是没变,我在timer里怎么改值看法

Vue.component('my-progress', {
    template: '\
            <div class="progress progress-bar-vertical" data-toggle="tooltip" data-placement="top">\
                <div class="progress-bar" role="progressbar" aria-valuenow="0" aria-valuemin="0" aria-valuemax="100" :style="{height: pgvalue}">{{pgvalue}}\
                </div>\
            </div>\
        ',
    data : function(){  

        return {
            pgvalue : '50%',
            intervalid1:'',
        }
    },
    computed:{

        changes : {
            get : function(){
                return this.pgvalue;
            },
            set : function(v){
                this.pgvalue =  v;
            }
        }
    },
    mounted : function(){

        this.todo()     
    },
    beforeDestroy () {

       clearInterval(this.intervalid1)
    },
    methods : {

        todo : function(){          
            this.intervalid1 = setInterval(function(){
                this.changes = ((Math.random() * 100).toFixed(2))+'%';
                console.log (this.changes);
            }, 3000);
        }
    },
})

here is the link: jsbin.com/safolom

这是链接: jsbin.com/safolom

回答by Bert

thisis not pointing to the Vue. Try

this不是指向 Vue。尝试

todo: function(){           
    this.intervalid1 = setInterval(function(){
        this.changes = ((Math.random() * 100).toFixed(2))+'%';
        console.log (this.changes);
    }.bind(this), 3000);
}

or

或者

todo: function(){  
    const self = this;          
    this.intervalid1 = setInterval(function(){
        self.changes = ((Math.random() * 100).toFixed(2))+'%';
        console.log (this.changes);
    }, 3000);
}

or

或者

todo: function(){  
    this.intervalid1 = setInterval(() => {
        this.changes = ((Math.random() * 100).toFixed(2))+'%';
        console.log (this.changes);
    }, 3000);
}

See How to access the correct thisinside a callback?

请参阅如何this在回调中访问正确的内容?

回答by fitorec

check this example:

检查这个例子:

Vue.component('my-progress-bar',{
 template:
`<div class="progress">
 <div
  class="progress-bar"
  role="progressbar"
  :style="'width: ' + percent+'%;'"
  :aria-valuenow="percent"
  aria-valuemin="0"
  aria-valuemax="100">
  {{ percent }}%
 </div>
</div>`,
 props: { percent: {default: 0} }
});


new Vue({
 el: '#app',
 data: {p: 50},
 created: function() {
  var self = this;
  setInterval(function() {
        if (self.p<100) {
             self.p++;
         }
    }, 100);
 }
});
<script src="https://cdn.jsdelivr.net/npm/vue"></script>
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" rel="stylesheet">

<div id='app'>
  <my-progress-bar :percent.sync='p'>
  </my-progress-bar>
  <hr>
  <button @click='p=0' class='btn btn-danger bt-lg btn-block'>
  Reset Bar Progress
  </button>
</div>