iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >详解Vuex的属性
  • 937
分享到

详解Vuex的属性

Vuex的属性Vuex属性 2022-11-13 14:11:20 937人浏览 安东尼
摘要

目录状态管理模式Mutation需遵守Vue的响应规则Vuex是专为vue.js应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预

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

简单来说:VuexVue框架中状态管理

图中绿色虚线包裹起来的部分就是Vue的核心,state中保存的就是公共状态,改变state的唯一方式就是通过mutations进行更改

状态管理模式

把组件的共享状态抽取出来,以一个全局单例模式管理。在这种模式下,组件数构成了一个巨大的视图,不管在树的哪个位置,任何组件都能获取状态或者触发行为,这就是状态管理模式。

应用场景有:单页应用中,组件之间的数据状态

应用实例:

  • 购物车功能
  • 下单页面选择优惠券按钮,点击进入优惠券页面,选择后返回到下单页,数据会绑定回来,显示已选择的优惠券
  • 登录状态等

Vuex的属性

  • state

    • Vuex就是一个仓库,仓库里面放了很多对象,其中state就是数据源存放地,对应一般Vue对象里面的data
    • state里面存放的数据是响应式的,Vue组件从store中读取数据,若是store中的数据发生改变,依赖这个数据的组件也会发生更新
    • 通过mapState把全局的stategetters映射到当前组件的computed计算属性中
  • getters

    • getters可以对state进行计算操作,它就是store的计算属性
    • 虽然在组件内也可以做计算属性,但是getters可以在多组件之间复用
    • 如果一个状态只在一个组件内使用,可以不用getters

Mutations

每个mutations都有一个字符串的事件类型(type)和一个回调函数(handler),这个回调函数就是实际进行状态修改的地方,并且它会接收state作为第一个参数:

const store = new Vuex.Store({
    state:{
        count:1
    },
    mutations:{
        increment(state){
            //变更状态
            state.count++
        }
    }
})

不能直接调用一个mutation handler。这个选项更像是事件注册,当触发一个类型为incrementmutations时,调用此函数。要唤醒一个mutation handler,需要调用相应的type调用store.commit方法

store.commit('increment')

提交载荷(payload)

可以向store.commit传入额外的参数,即mutation的载荷(payload)

state:{
    count:0
},
mutations:{
    increment(state,n){
        state.count += n
    }
}

//组件
store.commit('increment',10)

在大多数情况下,载荷应该是一个对象,这安样可以包含多个字段并且记录的mutation会更易读

state:{
    count:0
},
mutations:{
    increment(state,payload){
        state.count += payload
    }
}

//组件
store.commit('increment',{
    amount:10
})

Mutation需遵守Vue的响应规则

既然Vuex的store中的状态时响应式的,那么当我们变更状态时,监听状态的Vue组件也会自动更新。这也意味着Vuex中的mutation需要与使用Vue一样遵守一些注意事项:

最好提前在store中初始化好所有所需属性

当需要在对象上添加新属性时,应该

mutation必须是同步函数

使用Vue.set(obj,'newProp,123)

以新对象替换老对象。例如,利用对象展开运算符

state.obj = {...state.obj,newProp:123}

actions

action类似于mutation,不同在于:

action通过store.dispatch方法触发

store.dispatch('increment')

action内部执行异步操作

actions:{
    incrementAsync({commit}){
        setTimeout(() => {
            commit('increment')
        },1000)
    }
}

action同样支持载荷方式和对象方式进行分发

//以载荷形式分发
store.dispatch('incrementAsync',{
    amount:10
})
//以对象形式分发
store.dispatch({
    type:'incrementAsync',
    amount:10
})
  • action提交的是mutation,而不是直接变更状态
  • action可以包含任意异步操作

module

module可以让每个模块拥有自己的statemutationsactiongetters使得结构非常清晰,方便管理

const moduleA = {
  state: { ... },
  mutations: { ... },
  actions: { ... },
  getters: { ... }
}
const moduleB = {
  state: { ... },
  mutations: { ... },
  actions: { ... }
}

const store = new Vuex.Store({
 modules: {
  a: moduleA,
  b: moduleB
})

使用Vuex的好处

  • 多层嵌套的组件,兄弟组件间的状态会更好管理维护
  • 缓存一些当前要使用的请求远程或本地的数据集(刷新后会自动销毁)
  • 有了第二条就可以减少向服务器的请求,节省资源
  • 对于开发者来说,如果项目足够复杂,团队规模大,数据集中处理更利于程序的稳定和维护

参考文献:

https://v3.vuex.vuejs.org/zh/

到此这篇关于Vuex的属性的文章就介绍到这了,更多相关Vuex的属性内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 详解Vuex的属性

本文链接: https://www.lsjlt.com/news/171953.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 详解Vuex的属性
    目录状态管理模式Mutation需遵守Vue的响应规则Vuex是专为Vue.js应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预...
    99+
    2022-11-13
    Vuex的属性 Vuex属性
  • 详解Vuex的属性和作用
    目录Vuex是什么?Vuex的5个属性vuex 的 State 特性是? vuex 的 Getter 特性是? vuex 的 mauation 特性是? vuex 的 action ...
    99+
    2022-11-12
  • vuex中的state属性解析
    目录state属性介绍state的使用扩展vuex的State单一状态树在Vue组件中获得 Vuex 状态mapState辅助函数state属性介绍 state属性是Vuex中用于存...
    99+
    2022-11-13
  • vuex的属性有哪些
    今天小编给大家分享一下vuex的属性有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。 ...
    99+
    2022-10-19
  • CSS 属性详解:颜色属性
    CSS 属性详解:颜色属性CSS(层叠样式表)是一种用于描述网页样式的标记语言。其中,颜色属性是CSS中最常用的属性之一。通过使用颜色属性,我们可以改变页面中元素的文字颜色、背景颜色、边框颜色等,从而实现视觉上的效果和美化。一、颜色值的表示...
    99+
    2023-10-25
    color (颜色) background-color (背景颜色) border-color (边框颜色)
  • offsetwidth属性详解
    offsetWidth是一个只读属性,用于获取一个元素的可见宽度(包括边框、内边距和垂直滚动条的宽度)。具体来说,offsetWidth返回的是一个整数值,表示元素的整个宽度,包括以下几个部分:内容区宽度:元素内容的宽度,不包括边框和内边距...
    99+
    2023-07-10
  • vuex中的state属性怎么用
    这篇“vuex中的state属性怎么用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vuex中的state属性怎么用”文章吧...
    99+
    2023-06-30
  • IFRAME属性及详解
    IFRAME是一种HTML元素,用于在网页中嵌入另一个网页或文档。它的属性有以下几个:1. src:指定要嵌入的网页或文档的URL。...
    99+
    2023-09-21
    iframe
  • Vue中的computed属性详解
    目录插值表达式methodscomputed总结今天来说说vue中的计算属性computed,为了更好的理解计算属性的好处,我们先通过一个案例来慢慢 了解计算属性,有如下案例:定义两...
    99+
    2022-11-12
  • Android中的windowSoftInputMode属性详解
        在前面的一篇文章中,简单的介绍了一下如何实现软键盘不自动弹出,使用的方法是设置android:windowSoftInputMode属性。...
    99+
    2022-06-06
    Android
  • 详解Spring中的Transactional属性
    目录一、Transactional二、使用说明三、注解失效问题一、Transactional 声明式事务管理建立在AOP之上的。其本质是对方法前后进行拦截,然后在目标方法开始之前创...
    99+
    2022-11-12
  • jQuery的操作属性详解
    目录一、操作属性1、读取属性值:attr(属性名)2、修改属性值(1)attr(key,value)(2)attr(key,fn)(3)attr({属性名1:属性值,属性名2:属性值...
    99+
    2022-11-12
  • 详解Vue的监听属性
    目录Vue监听属性什么是监听属性?监听属性和计算属性的区别?监听属性的使用深度监听立即调用总结Vue监听属性 什么是监听属性? 所谓监听就是对内置对象的状态或者属性变化进行监听并且做...
    99+
    2022-11-12
  • vuex中的5个属性使用方法举例讲解
    目录一,Vuex简介二,Vuex五个核心属性1:state2:getters3:mutations4:actions5:modules三,Vuex使用方法1:安装Vuex:npm i...
    99+
    2023-05-18
    vuex的五个属性 vuex的五个属性及使用方法 vuex的属性有哪些
  • 详解jquery方法属性
    目录1.jquery简介2.jquery选择器2.1基本选择器5种2.2 关系选择器4种2.3基本过滤选择器8种2.4内容过滤选择器4种2.5可见性过滤选择器2种2.6属性过滤选择器...
    99+
    2022-11-12
  • android 布局属性详解
    android:id 为控件指定相应的ID android:text 指定控件的文本,置尽量使用strings.xml android:grivity 指定控件的基本位置 ,比...
    99+
    2022-06-06
    布局 属性 Android
  • Vue之ref属性详解
    总结 本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程网的更多内容! ...
    99+
    2022-11-12
  • css3中transition属性详解
    CSS3中的transition属性用于设置元素在一定时间内的过渡效果。它允许我们在元素的不同状态之间平滑地过渡,从而实现更加流畅的...
    99+
    2023-09-23
    css3
  • Dataformatstring属性设置(详解)
    DataFormatString属性是用于设置数据呈现格式的属性。它可用于各种数据控件,如Label、GridView、DataLi...
    99+
    2023-09-15
    属性
  • 详解SQL Server 中的 ACID 属性
    目录SQL Server 中的事务是什么?事务的 ACID 属性是什么?SQL Server 中事务的原子性SQL Server 中事务的一致性SQL Server 中事务的隔离性SQL Server 中事务的持久性SQ...
    99+
    2022-07-13
    SQL Server ACID SQL Server  ACID 属性
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作