IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> VueX(Vue状态管理模式) -> 正文阅读

[JavaScript知识库]VueX(Vue状态管理模式)

vuex是什么?

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。也是一种组件间通信的方式。

应用vuex的好处

  • 能够集中管理共享的数据,易于开发和后期的维护
  • 高效的实现组件之间的数据共享,提高开发效率
  • 存在vuex的数据也是响应式的,能够实时保持数据与页面的同步

应用场景

多个组件共享数据或者是跨组件传递数据时

vuex基本使用

  • 安装
npm i vuex -s
  • 导入vuex
import Vuex from 'vuex'
Vue.use(Vuex)
  • 在项目的根目录下新增一个store文件夹,在该文件夹内创建index.js并编写
const countAbout = {
 namespaced:true, //开启命名空间
 state:{x:1},
 mutations:{ ... },
 actions:{ ... },
 getters:{
 bigResult(state){
 return state.sum * 10
 }
 }
}
const store = new Vuex.Store({
 modules:{
 countAbout
 }
})
  • main.js引入store并全局挂载store到vue上
new Vue({
  store,
  router,
  render: h => h(App)
}).$mount('#app')

?

VueX中的核心内容

在VueX对象中,其实不止有state,还有用来操作state中数据的方法集,以及当我们需要对state中的数据需要加工的方法集等等成员。

成员列表:

  • state 存放状态
  • mutations? 操作state成员
  • getters 加工state成员给外界
  • actions 异步操作
  • modules 模块化状态管理

Actions

异步操作?,context?上下文(相当于箭头函数中的this)对象,value挂载参数。

action的存在就是为了让mutations中的方法能在异步操作中起作用。向后端请求时或者说出现异步操作时,需要dispatch?VueX中actions的方法,以保证数据的同步。

Actions中的方法有两个默认参数

  • context 上下文(相当于箭头函数中的this)对象
  • value挂载参数
actions:{
    jia(content,value){}
}

使用:

actions:{
    //content一个对象包含有state和commit属性等,value  参数
    jia(content,value){
      console.log('jia1',content)
      console.log('jia2',value)//1  要操作的参数
      content.commit('JAV',value)
    }
  },
  // mutations 操作state成员
  mutations:{
    JAV(state,value){
      console.log("+",state,value)
      state.result+=value;
    },
    JIAN(state,value){
      state.result-=value
    }
  },
  state:{
    result:100,
    name:'xilin',
    school:'广西'
  },
  // 可以对state中的成员加工后传递给外界
  getters:{
    bigResult(state){
      return state.result*10;
    }
  },
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-24 14:50:47  更:2021-10-24 14:52:59 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/13 2:45:53-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码