当前位置: 首页 > news >正文

南宁手机网站制作公司百度竞价广告投放

南宁手机网站制作公司,百度竞价广告投放,阿里云万网网站制作,centos7搭建wordpress📖摘要 今天分享下 —— Vue系列:理解Vuex 的一些基本知识,欢迎关注! 当我们在项目中使用props来处理数据共享关系时,多层级的组件之间数据传递真的是很繁琐,费劲且不易维护,vuex的出现&#xf…

📖摘要


今天分享下 —— Vue系列:理解Vuex 的一些基本知识,欢迎关注!

当我们在项目中使用props来处理数据共享关系时,多层级的组件之间数据传递真的是很繁琐,费劲且不易维护,vuex的出现,就可以完美帮我们解决这个问题。


🌂分享:几个关键字段的含义


✨1. vuex是什么?

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态。

白话:vuex 就是帮我们存储一下多个组件共享的数据,方便我们对其读取和更改。


✨2. State

官方解释:Vuex 使用单一状态树,用一个对象就包含了全部的应用层次状态。它便作为一个唯一的数据源而存在。这也就意味着, 每个应用将仅仅包含一个 store 实例。

白话:组件中所要共享的数据,我们就会抽取一个 store,而 state 即是我们可以共享的数据。


3. Mutations

更改 Vuexstore 中的状态的唯一方法是提交 mutation

Vuex 中的 mutation 非常类似于事件:每个 mutation 都有一个字符串的事件类型和一个回调函数。

这个回调函数就是我们实际进行状态更改的地方。并且它会接受 state 第一个参数。

白话:可以理解为更改state的唯一途径就是 mutation (同步)


4. Actions

类似于 Mutation,不同在于:

  • Action 提交的是 mutation,而不是直接更改状态
  • Action 可以包含任意一步操作

白话:Actions 也可以更改 state,但是是通过 commit,提交到 mutation,不直接更改(异步)


5. Getters

Vuex 允许我们在 store 中定义 getter(可以认为是 store 的计算属性)。

就像计算属性 computed 一样,getter 的返回值会根据它的依赖被缓存起来。

且只有当它的依赖值发生了改变才会被重新计算。


6. mapState

是一个辅助函数,当一个组件需要获取多个状态时候,将这些状态都声明为计算属性会有些重复和冗余。

为了解决这个问题,我们可以使用 mapState 辅助函数帮助我们生成计算属性。

白话:即帮我们获取对应的 state


7. mapAction

是一个辅助函数,个人觉得比 dispatch 使用起来方便,主要是创建组件方法分发 action,推荐使用。


🌂分享:实例


✨1. 安装

npm install vuex --save

✨2. 目录结构 (此项目使用是vue-admin-template脚手架)

用例链接:https://github.com/yzren/Vuex.git

- build
- node-modules
- public
- src- api- components- layout-  components- appMain.vue- child.vue- router- store- modules- app.js (我们例子中写vuex相关信息文件)- index.js- app.vue- main.js

✨3. 简单实例

  1. store 文件夹下 modules 文件夹下添加 app.js 文件
const state = {count: 1
}const mutations = {SET_ADD_COUNT: (state) => {state.count++},SET_SUBTRACT_COUNT: (state) => {state.count--}
}const actions = {// 加add({ commit }) {commit('SET_ADD_COUNT')},// 减subtract({ commit }) {commit('SET_SUBTRACT_COUNT')}}export default {// namespaced: true,state,mutations,actions
}
  1. store 文件夹下新建 index.js 文件,index 内容:
import Vue from 'vue'
import Vuex from 'vuex'
import app from './modules/app'Vue.use(Vuex)const store = new Vuex.Store({modules: {app //封装的存放state下count的方法}
})export default store
  1. main.js 中引入 store 文件
    
import store from './store'
...
new Vue({el: '#app',router,store,render: h => h(App)
})
  1. 具体到组件中使用,我们以 layout 内组件为例子
    AppMain.vue
<template><section class="app-main"><h2>父亲组件</h2><p>count计算结果 :<strong>{{ count }}</strong></p><el-button size="small" @click="addFn">+</el-button><el-button size="small" @click="subtractFn">-</el-button><div><child /></div></section>
</template><script>
import { mapState, mapActions } from 'vuex'
import Child from './chind'export default {name: 'AppMain',components: {Child},computed: {...mapState({count: state => state.app.count})},methods: {...mapActions(['add', 'subtract']),addFn() {this.add()},subtractFn() {this.subtract()}}
}
</script>
...

child.vue

<template><section class="app-main"><h2>子组件</h2><p>count计算结果 :<strong>{{ count }}</strong></p><el-button size="small" @click="addFn">+</el-button><el-button size="small" @click="subtractFn">-</el-button></section>
</template><script>
import { mapState, mapActions } from 'vuex'export default {name: 'Child',computed: {...mapState({//引用countcount: state => state.app.count})},methods: {//分发action,即引入之后,就能通过【this.store中的方法名】,//调用store内相对应的方法,//此例调用的就是action的add和subtract方法...mapActions(['add', 'subtract']),addFn() {this.add()},subtractFn() {this.subtract()}}
}
</script>
...

✨4. 异步实例

主要展示 store 内文件相关代码,其调用于以上简单实力类似

//封装的axios文件
import http from '@common/http';//封装的需要调用后端的接口文件
import { api } from '@common/config';//共享的数据
const state = {listData: {}
};const actions = {// 获取gitTestList({state, commit}, params) {// 缓存已请求数据if (state.listData[params.id]) {return Promise.resolve(state.listData[params.id]);}return http.get(api.testApi, { params, notLoading: true }).then(res => {commit('SET_TEST_LIST', res.data);return res.data;});}
};const mutations = {//设置列表相应信息SET_TEST_LIST(state, data) {state.listData[data.id] = data;}
};export default {state,actions,mutations
};

🎉最后

  • 更多参考精彩博文请看这里:《陈永佳的博客》

  • 喜欢博主的小伙伴可以加个关注、点个赞哦,持续更新嘿嘿!

http://www.lbrq.cn/news/2481877.html

相关文章:

  • 做自己的彩票网站数据营销
  • dw做网站教程视频公司关键词排名优化
  • 外贸主动营销网站建设理发培训专业学校
  • 泰州哪家做网站建设比较好免费建站哪个网站最好
  • 智博教育的网络营销是什么上海何鹏seo
  • 青海餐饮网站建设公司网络促销的方法有哪些
  • 36kr网站用什么做的软件开发培训机构排名
  • 在合肥哪里学网站建设网络营销出来可以干什么工作
  • 类似b站的网站怎么做的合肥网站推广公司哪家好
  • 北京软件开发公司排宁波seo网络推广咨询价格
  • 鞍山市做网站公司重庆网站优化排名推广
  • 南京网站制作站长工具在线
  • 专门做品牌折扣的网站查询网站相关网址
  • 稳健 安全的网站设计制作徐州seo顾问
  • 云南建设厅网站删除有什么公司要做推广的
  • 网站手机端建设上海网络推广招聘
  • 北海做网站公司长沙优化排名
  • 如何做网站搜索引擎优化搜索引擎优化主要包括
  • 品牌型网站制作哪如何快速推广自己的网站
  • app网站制作要多少费用做网站的外包公司
  • 电子商务网站开发公司批量查询权重
  • bootstrap风格网站佛山百度网站快速排名
  • 媒体135网站百度推广关键词怎么设置好
  • cms中文名称是什么seo快速排名优化
  • 宁波外贸seo网站建设长沙seo咨询
  • 室内设计说明200字郑州谷歌优化外包
  • 手机版网站优化宁波公司做网站
  • 做羞羞事的网站沙坪坝区优化关键词软件
  • 做ic的电子网站有哪些朋友圈推广平台
  • 2020年购物app排行湖北seo网站推广
  • Rust赋能土木工程数字化
  • python 检测蜂窝网络,实现掉网自动拨号
  • C语言函数精讲:从入门到精通( 指针(5))
  • 《Java 程序设计》第 6 章 - 字符串
  • 主要分布在腹侧海马体(vHPC)CA1区域(vCA1)的混合调谐细胞(mixed-tuning cells)对NLP中的深层语义分析的积极影响和启示
  • 【C#补全计划:类和对象(七)—— 重写虚方法】