小孟快冲 2023-08-18 14:09 采纳率: 100%
浏览 5
已结题

定时器setinterval函数+数据页面渲染

为什么不能将数据渲染到页面上


```html
<template>
  <p v-html="state"></p>
  <button @click="asd">切换</button>
 </template>
     
 <script>
 export default {
   data() {
     return {
       state:"问题接收"
     };
   },
   methods: {
     asd(){
       let states= [ "问题解析", "发送给ChatGPT", "等待ChatGPT回答"]
       let i=0
       const timeTop = setInterval(function () {
         this.state=states[i]
         console.log(this.state)
         i++
         if (i >=states.length) {
           clearInterval(timeTop);
         }
         
       }, 1000);
     }
   },
 
 };
 </script>

img

但是把定时器里的函数,换成箭头函数的话数据就会成功渲染(请问是什么原因)

img


```

  • 写回答

3条回答 默认 最新

  • 雾里桃花 2023-08-18 14:21
    关注

    this指向的问题,使用function的话this指向的是计时器,使用箭头函数this指向的是计时器的上一级,也就是vue

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 8月29日
  • 已采纳回答 8月21日
  • 创建了问题 8月18日

悬赏问题

  • ¥15 校内二手商品转让网站
  • ¥20 高德地图聚合图层MarkerCluster聚合多个点,但是ClusterData只有其中部分数据,原因应该是有经纬度重合的地方点,现在我想让ClusterData显示所有点的信息,如何实现?
  • ¥100 求Web版SPC控制图程序包调式
  • ¥20 指导如何跑通以下两个Github代码
  • ¥15 大家知道这个后备文件怎么删吗,为啥这些文件我只看到一份,没有后备呀
  • ¥15 C++为什么这个代码没报错运行不出来啊
  • ¥15 一道ban了很多东西的pyjail题
  • ¥15 关于#r语言#的问题:如何将生成的四幅图排在一起,且对变量的赋值进行更改,让组合的图漂亮、美观@(相关搜索:森林图)
  • ¥15 C++识别堆叠物体异常
  • ¥15 微软硬件驱动认证账号申请