0

对于一个刽子手游戏,我有一个Word.vue组件,我试图在其中初始化一个名为的数组,wordToGuessAsArray其中包含n 个空项(n = 要猜测的单词中的字母数):

<template>
  <section>
    <div v-for="(letter, i) in wordToGuessAsArray" :key="i">
    </div>
  </section>
</template>

<script>
export default {
  computed: {
    wordToGuessAsArray () {
      return this.$store.state.wordToGuessAsArray
    }
  },
  mounted () {
    const wordToGuess = 'strawberry'
    for (var i = 0; i < wordToGuess.length; i++) {
      this.$store.commit('SET_WORD_AS_ARRAY_PUSH')
    }
  }
}
</script>

以下是我store与此问题相关的内容:

state: {
  wordToGuessAsArray: [],
},
mutations: {
  SET_WORD_AS_ARRAY_PUSH (state) {
    state.wordToGuessAsArray.push('')
  },
  SET_WORD_AS_ARRAY (state, value) {
    state.wordToGuessAsArray[value.i] = value.letter
  }
}

我的问题如下。在我的Keyboard.vue组件中,当用户选择一个确实属于要猜测的单词的字母时,我会更新我的状态:

this.$store.commit('SET_WORD_AS_ARRAY', { letter, i })

我希望这个突变能在Word.vue这里更新我的组件中的单词:

<div v-for="(letter, i) in wordToGuessAsArray" :key="i">

然而事实并非如此。wordToGuessAsArray似乎没有反应,为什么?

4

1 回答 1

1

这是因为state.wordToGuessAsArray[value.i] = value.letter没有反应。因为 Vue.js 只观察数组方法,比如pushor splice

你需要做this.$set(state.wordToGuessAsArray, value.i, value.letter);

或者在 Vuex 中: Vue.set(state.wordToGuessAsArray, value.i, value.letter);并在你的文件中导入 Vue。

在这里阅读更多:

https://vuejs.org/v2/guide/reactivity.html#Change-Detection-Caveats

Vuejs 和 Vue.set(),更新数组

于 2019-11-05T20:50:32.557 回答