Vue-使用方法更新数据时组件不会重新渲染

时间:2020-05-31 06:09:23

标签: typescript vue.js methods components render

我有一个非常简单的vue组件,看起来像这样:

<template>
  <div class="incrementor">
    <p v-text="counter"></p>
    <button v-on:click="increment()">Increment</button>
  </div>
</template>

<script lang="ts" src="../scripts/incrementor.ts"></script>
<style lang="scss" src="../styles/incrementor.scss"></style>

这是我的“ incrementor.ts”脚本文件:

import { Component, Vue, Prop } from "vue-property-decorator";

@Component({})
export default class Incrementor extends Vue {
  private counter: number = 0;

  increment = () => {
    this.counter++;
  };
}

我的问题是,当我单击按钮时,我可以在控制台中看到计数器增加,但是组件没有重新呈现,因此浏览器中的“计数器”文本保持为0。

我知道我可以这样做:

<template>
  <div class="incrementor">
    <p v-text="counter"></p>
    <button v-on:click="counter++">Increment</button>
  </div>
</template>

<script lang="ts" src="../scripts/incrementor.ts"></script>
<style lang="scss" src="../styles/incrementor.scss"></style>

它可以工作,但是我希望能够使用自己的方法。

1 个答案:

答案 0 :(得分:0)

这里的几个问题:

  1. 我们需要像下面这样传递函数引用,而不是直接调用函数:

    <button v-on:click="increment">
    
  2. 接下来,如docs中所述,可以将组件方法声明为实例方法,例如:

    increment() {
       this.counter++;
    };
    

实施这些更改后,增量计数器将正常工作。

Edit vue-class-component-example-k6bc4