VueJS v3、Vuex 和 Composition API 以及输入字段上的 v-model

Posted

技术标签:

【中文标题】VueJS v3、Vuex 和 Composition API 以及输入字段上的 v-model【英文标题】:VueJS v3, Vuex and Composition API and v-model on input field 【发布时间】:2021-12-21 05:32:50 【问题描述】:

问题

我有一些从 Vuex 商店获取搜索查询的代码。我正在使用计算属性来获取搜索查询,然后将其绑定到输入字段的 v-model。我希望能够通过输入字段编辑/更改搜索词,然后提交新的搜索查询,然后执行新的搜索查询。

但是由于计算属性是“只读”,当我在输入字段中更改搜索查询时,它不会更新搜索查询,并导致警告:

vendor.js:16674 Write operation failed: computed value is readonly

问题

如何从 Vuex 获取搜索查询、填充输入字段、更改/更新它,然后提交更改后的查询?我试图为组合 API 找到一个 computed 设置器,但找不到。

有什么想法吗?还是我应该看看另一种方法?

下面是代码

<template>

  <form role="search"
      aria-label="Sitewide"
      @submit.prevent="submitSearch"
      autocomplete="off">

    <input type="text" v-model="searchQuery" />
    <button type="button" v-on:click="submitSearch">Search</button>

  </form>
</template>

<script>
import  computed  from 'vue'
import  useStore  from 'vuex'

export default 
   name: "ProductSearchBox",
   setup() 
      const store = useStore();
      const searchQuery = computed(() => store.getters["search/getFiltersSearchTerm"]);

      const submitSearch = () => 
        store.dispatch('search/performSearch', searchQuery);
      

      return 
          searchQuery,
          submitSearch
      
   

</script>

【问题讨论】:

【参考方案1】:

这听起来更像是watch 的用例。

const searchQuery = ref('');
watch(
  () => store.getters["search/getFiltersSearchTerm"],
  (term) => searchQuery.value = term
);

【讨论】:

你,我的朋友,是个天才。这完美无缺。谢谢【参考方案2】:

您可以像这样为 v-model 使用计算属性:

<template>
    <form role="search"
        aria-label="Sitewide"
        @submit.prevent="submitSearch"
        autocomplete="off">

        <input type="text" v-model="searchQuery" />

    </form>
</template>

<script>
import  computed  from 'vue'
import  useStore  from 'vuex'

export default 
   name: "ProductSearchBox",
   setup() 
      const store = useStore();
      const searchQuery = computed(
         get: () => store.getters['search/getFiltersSearchTerm'],
         set: (newValue) => store.commit('search/yourMutation', newValue)
      );
      
      const submitSearch = () => 
        store.dispatch('search/performSearch', searchQuery);
      

      return 
          searchQuery,
          submitSearch
      
   

</script>

【讨论】:

以上是关于VueJS v3、Vuex 和 Composition API 以及输入字段上的 v-model的主要内容,如果未能解决你的问题,请参考以下文章

VUEJS 3 组合计算和 vuex 没有反应

Vuex/Vuejs:在 vuex 存储中访问 localStorage

VueJS + Vuex + Vuetify 导航抽屉

在 vuejs 和 vuex 上重复 websocket 的发射

使用 vuejs / vuex 使用 ID 和 ParentId 分组数组

如何使用VueJS和Vuex重置表单元素