当前位置:首页 > 科技  > 软件

Vuex原理:通过Vuex实现TodoList

来源: 责编: 时间:2024-09-10 09:50:02 36观看
导读什么是Vuex「Vuex」 是一个专为 Vue.js 应用程序开发的状态管理模式。它可以集中管理应用中的组件共享状态,并提供一些工具来保持状态的一致性。Vuex 主要用于解决以下问题:「组件通信」:在大型的 Vue.js 应用中,多个组件

什么是Vuex

「Vuex」 是一个专为 Vue.js 应用程序开发的状态管理模式。它可以集中管理应用中的组件共享状态,并提供一些工具来保持状态的一致性。Vuex 主要用于解决以下问题:wix28资讯网——每日最新资讯28at.com

  • 「组件通信」:在大型的 Vue.js 应用中,多个组件可能需要共享一些状态(数据)。而通过简单的组件通信方式(props、自定义事件)在复杂的组件关系中可能会变得不够灵活或繁琐。
  • 「状态管理」:Vue.js 的单向数据流通过 props 将数据从父组件传递给子组件,但对于多层嵌套的组件结构,数据流管理可能变得复杂。Vuex 提供了一种集中式管理状态的方式,使得状态的变更变得可预测且易于调试。

以下是 Vuex 的核心概念:wix28资讯网——每日最新资讯28at.com

1. 「State(状态)」

Vuex 使用一个包含应用层级状态的对象,即 State。这个状态是响应式的,当状态发生变化时,相关组件将自动更新。wix28资讯网——每日最新资讯28at.com

const store = new Vuex.Store({  state: {    count: 0  }});

2. 「Mutations(变更)」

状态的变更必须通过 Mutations 来进行。Mutations 是同步函数,用于修改状态。通过这种方式,可以追踪状态的变更,并且可以实现一些限制条件,确保状态的可控性。wix28资讯网——每日最新资讯28at.com

const store = new Vuex.Store({  state: {    count: 0  },  mutations: {    increment(state) {      state.count++;    }  }});

3. 「Actions(动作)」

Actions 是用于提交 Mutations 的函数,可以包含异步操作。通过 Actions,可以更灵活地处理业务逻辑,例如异步请求或条件判断。wix28资讯网——每日最新资讯28at.com

const store = new Vuex.Store({  state: {    count: 0  },  mutations: {    increment(state) {      state.count++;    }  },  actions: {    incrementAsync({ commit }) {      setTimeout(() => {        commit('increment');      }, 1000);    }  }});

4. 「Getters(获取器)」

Getters 允许组件在访问状态时进行计算,类似于 Vue 组件中的计算属性。Getters 的结果会被缓存,只有依赖的状态发生变化时才会重新计算。wix28资讯网——每日最新资讯28at.com

const store = new Vuex.Store({  state: {    count: 0  },  getters: {    doubleCount: state => state.count * 2  }});

5. 「Modules(模块)」

Vuex 允许将 Store 分割成模块,每个模块拥有自己的 state、mutations、actions、getters。这样可以更好地组织大型的 Store。wix28资讯网——每日最新资讯28at.com

const moduleA = {  state: { /* ... */ },  mutations: { /* ... */ },  actions: { /* ... */ },  getters: { /* ... */ }};const store = new Vuex.Store({  modules: {    a: moduleA  }});

6. 单一状态树

Vuex 使用一个单一的状态树来管理应用中的所有状态。这使得整个应用的状态变化可追踪和调试。wix28资讯网——每日最新资讯28at.com

7. Plugin(插件)

Vuex 允许通过插件扩展其功能。插件是一个函数,可以在每次 mutation 发生时执行一些自定义的逻辑,例如记录日志或持久化存储。wix28资讯网——每日最新资讯28at.com

// Vuex 插件示例const myPlugin = store => {  // 每次 mutation 时调用  store.subscribe((mutation, state) => {    console.log('mutation type:', mutation.type);  });};

8. 严格模式

Vuex 提供了严格模式,用于检测 State 的变更是否是通过 Mutations 进行的。在开发环境中启用严格模式可以帮助捕获不合规的状态变更。wix28资讯网——每日最新资讯28at.com

const store = new Vuex.Store({  // ...  strict: process.env.NODE_ENV !== 'production'});

通过这些概念,Vuex 提供了一种集中式状态管理的解决方案,使得状态在应用中的传递和管理更为清晰和可维护。Vuex 不是必需的,尤其对于小型应用可能会显得繁琐,但在大型、复杂的应用中,它提供了一种有组织的方法来管理状态。wix28资讯网——每日最新资讯28at.com

利用Vuex实现一个tudoList

简单了解一下Vuex之后呢,实现一个小案例。下面是一个使用 Vue 3 和 Vuex 的简单的 Todo List 示例。使用前需要先下载依赖。这个应该都会吧。创建一个 store 文件夹,并在其中创建 index.js 文件来定义 Vuex 的 store:wix28资讯网——每日最新资讯28at.com

// store/index.jsimport { createStore } from 'vuex';export default createStore({  state: {    todos: []  },  mutations: {    addTodo(state, todo) {      state.todos.push(todo);    },    toggleTodo(state, index) {      state.todos[index].completed = !state.todos[index].completed;    },    removeTodo(state, index) {      state.todos.splice(index, 1);    }  },  actions: {    addTodoAsync({ commit }, todo) {      setTimeout(() => {        commit('addTodo', todo);      }, 1000);    }  },  getters: {    completedTodos: state => state.todos.filter(todo => todo.completed),    remainingTodos: state => state.todos.filter(todo => !todo.completed)  }});

然后在 App.vue 文件中使用这个 store:wix28资讯网——每日最新资讯28at.com

// App.vue<template>  <div id="app">    <h1>Todo List</h1>    <form @submit.prevent="addTodo">      <input v-model="newTodo" placeholder="Add a new todo" />      <button type="submit">Add</button>    </form>    <div>      <h2>Todo Items</h2>      <ul>        <li v-for="(todo, index) in todos" :key="index">          <input type="checkbox" v-model="todo.completed" />          {{ todo.text }}          <button @click="removeTodo(index)">Remove</button>        </li>      </ul>    </div>    <div>      <h2>Completed Todos</h2>      <ul>        <li v-for="(todo, index) in completedTodos" :key="index">          {{ todo.text }}        </li>      </ul>    </div>    <div>      <h2>Remaining Todos</h2>      <ul>        <li v-for="(todo, index) in remainingTodos" :key="index">          {{ todo.text }}        </li>      </ul>    </div>  </div></template><script>import { computed } from 'vue';import { useStore } from 'vuex';export default {  name: 'App',  data() {    return {      newTodo: ''    };  },  methods: {    addTodo() {      this.$store.commit('addTodo', { text: this.newTodo, completed: false });      this.newTodo = '';    },    removeTodo(index) {      this.$store.commit('removeTodo', index);    }  },  computed: {    todos() {      return this.$store.state.todos;    },    completedTodos: computed(() => useStore().getters.completedTodos),    remainingTodos: computed(() => useStore().getters.remainingTodos)  }};</script><style>#app {  font-family: Avenir, Helvetica, Arial, sans-serif;  text-align: center;  color: #2c3e50;  margin-top: 60px;}form {  margin-bottom: 20px;}ul {  list-style-type: none;  padding: 0;}li {  margin-bottom: 5px;}</style>

这个示例中,我们使用 Vuex 来管理 todo 列表的状态,包括添加新 todo、切换 todo 状态、删除 todo 等功能。在模板中,我们使用了 v-for 指令来渲染 todo 列表,并通过 Vuex 的 getters 计算属性显示已完成和未完成的 todo 列表。wix28资讯网——每日最新资讯28at.com

小结

使用vuex能够实现组件之间的通信,它是一个状态管理机制,集中管理组件共享状态。wix28资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-112757-0.htmlVuex原理:通过Vuex实现TodoList

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Uniapp 开发神器,效率翻倍!

下一篇: 高性能、无侵入的 Java 性能监控神器

标签:
  • 热门焦点
  • Find N3入网:最高支持16+1TB

    Find N3入网:最高支持16+1TB

    OPPO将于近期登场的Find N3折叠屏目前已经正式入网,型号为PHN110。本次Find N3在外观方面相比前两代有很大的变化,不再是小号的横向折叠屏,而是跟别的厂商一样采用了较为常见的
  • 对标苹果的灵动岛 华为带来实况窗功能

    对标苹果的灵动岛 华为带来实况窗功能

    继苹果的灵动岛之后,华为也在今天正式推出了“实况窗”功能。据今天鸿蒙OS 4.0的现场演示显示,华为的实况窗可以更高效的展现出实时通知,比如锁屏上就能看到外卖、打车、银行
  • 红魔电竞平板评测:大屏幕硬实力

    红魔电竞平板评测:大屏幕硬实力

    前言:三年的疫情因为要上网课的原因激活了平板市场,如今网课的时代已经过去,大家的生活都恢复到了正轨,这也就意味着,真正考验平板电脑生存的环境来了。也就是面对着这种残酷的
  • Redmi Pad评测:红米充满野心的一次尝试

    Redmi Pad评测:红米充满野心的一次尝试

    从Note系列到K系列,从蓝牙耳机到笔记本电脑,红米不知不觉之间也已经形成了自己颇有竞争力的产品体系,在中端和次旗舰市场上甚至要比小米新机的表现来得更好,正所谓“大丈夫生居
  • 容量越大越不坏?24万块硬盘故障率报告公布 这些产品零故障

    容量越大越不坏?24万块硬盘故障率报告公布 这些产品零故障

    8月5日消息,云存储服务商Backblaze发布了最新的硬盘故障率报告,年故障率有所上升。Backblaze发布的硬盘季度统计数据,其中包括故障率等重要方面。这些结
  • 8月见!小米MIX Fold 3获得3C认证:支持67W快充

    8月见!小米MIX Fold 3获得3C认证:支持67W快充

    这段时间以来,包括三星、一加、荣耀等等有不少品牌旗下的最新折叠屏旗舰都得到了不少爆料,而小米新一代折叠屏旗舰——小米MIX Fold 3此前也屡屡被传
  • 华为Mate 60系列用上可变灵动岛:正式版体验将会更出色

    华为Mate 60系列用上可变灵动岛:正式版体验将会更出色

    这段时间以来,关于华为新旗舰的爆料日渐密集。据此前多方爆料,今年华为将开始恢复一年双旗舰战略,除上半年推出的P60系列外,往年下半年的Mate系列也将
  • 滴滴违法违规被罚80.26亿 共存在16项违法事实

    滴滴违法违规被罚80.26亿 共存在16项违法事实

    滴滴违法违规被罚80.26亿 存在16项违法事实开始于2121年7月,历经一年时间,网络安全审查办公室对“滴滴出行”网络安全审查终于有了一个暂时的结束。据“网信
  • 利用职权私自解除被封帐号 Meta开除20多名员工

    利用职权私自解除被封帐号 Meta开除20多名员工

    11月18日消息,据外媒援引知情人士表示,过去一年时间内,Facebook母公司Meta解雇或处罚了20多名员工以及合同工,指控这些人通过内部系统以不当方式重置用户帐号,其
Top
Baidu
map