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

网站建设建设报价学校网站建设论文

网站建设建设报价,学校网站建设论文,湖南省郴州市简介,交互设计的方法和技巧前言 学习前端一段时间了,因为一直是做Python开发,所以凭借着语言的通性学习Javascript、Vue轻快很多,但一些碎片化的知识及插件的使用方法还是需要记录一下,时而复习,形成系统化的知识体系(PS:…

前言

学习前端一段时间了,因为一直是做Python开发,所以凭借着语言的通性学习Javascript、Vue轻快很多,但一些碎片化的知识及插件的使用方法还是需要记录一下,时而复习,形成系统化的知识体系(PS:主要是年纪大了记不住)

一、Vuex是什么

概念:专门在Vue中实现集中式状态(数据)管理的一个Vue插件,对Vue应用中多个组件的共享状态进行集中式的管理(读/写),也是一种组件间通信的方式,且适用于任意组件间通信。
换句话说就是实现了一个东西来统一集中管理这些数据。

二、什么时候使用Vuex

  1. 多个组件依赖于同一状态
  2. 来自不同组件的行为需要变更同一状态

三、Vuex工作原理图

在这里插入图片描述
借用尚硅谷张天禹老师的比喻来解释这张图:
客人(Vue Components)去饭店吃饭,告诉(Dispatch)服务员(Actions)吃什么菜,服务员就把要点的菜交给后厨(Mutations)来加工,把做好的菜(State)给到客人。

四、编码实现

搭建Vuex环境

  1. 创建文件:src/store/index.js
//引入Vue核心库
import Vue from 'vue'
//引入Vuex
import Vuex from 'vuex'
//应用Vuex插件
Vue.use(Vuex)//准备actions对象——响应组件中用户的动作
const actions = {}
//准备mutations对象——修改state中的数据
const mutations = {}
//准备state对象——保存具体的数据
const state = {}//创建并暴露store
export default new Vuex.Store({actions,mutations,state
})
  1. main.js中创建vm时传入store配置项
......
//引入store
import store from './store'
......//创建vm
new Vue({el:'#app',render: h => h(App),store
})

基本使用

1.初始化数据、配置actions、配置mutations,操作文件store.js

//引入Vue核心库
import Vue from 'vue'
//引入Vuex
import Vuex from 'vuex'
//引用Vuex
Vue.use(Vuex)const actions = {//响应组件中加的动作jia(context,value){// console.log('actions中的jia被调用了',miniStore,value)context.commit('JIA',value)},
}const mutations = {//执行加JIA(state,value){// console.log('mutations中的JIA被调用了',state,value)state.sum += value}
}//初始化数据
const state = {sum:0
}//创建并暴露store
export default new Vuex.Store({actions,mutations,state,
})

2.组件中读取vuex中的数据:$store.state.sum

3.组件中修改vuex中的数据:$store.dispatch('action中的方法名',数据)或 $store.commit('mutations中的方法名',数据)

备注:若没有网络请求或其他业务逻辑,组件中也可以越过actions,即不写dispatch,直接编写commit

具体案例:

index.js

//该文件用于创建Vuex中最为核心的store
import Vue from 'vue'
//引入Vuex
import Vuex from 'vuex'
//应用Vuex插件
Vue.use(Vuex)//准备actions——用于响应组件中的动作
const actions = {/* jia(context,value){console.log('actions中的jia被调用了')context.commit('JIA',value)},jian(context,value){console.log('actions中的jian被调用了')context.commit('JIAN',value)}, */jiaOdd(context,value){console.log('actions中的jiaOdd被调用了')if(context.state.sum % 2){context.commit('JIA',value)}},jiaWait(context,value){console.log('actions中的jiaWait被调用了')setTimeout(()=>{context.commit('JIA',value)},500)}
}
//准备mutations——用于操作数据(state)
const mutations = {JIA(state,value){console.log('mutations中的JIA被调用了')state.sum += value},JIAN(state,value){console.log('mutations中的JIAN被调用了')state.sum -= value}
}
//准备state——用于存储数据
const state = {sum:0 //当前的和
}//创建并暴露store
export default new Vuex.Store({actions,mutations,state,
})

Count.vue

<template><div><h1>当前求和为:{{$store.state.sum}}</h1><select v-model.number="n"><option value="1">1</option><option value="2">2</option><option value="3">3</option></select><button @click="increment">+</button><button @click="decrement">-</button><button @click="incrementOdd">当前求和为奇数再加</button><button @click="incrementWait">等一等再加</button></div>
</template><script>export default {name:'Count',data() {return {n:1, //用户选择的数字}},methods: {increment(){// commit 是操作 mutationsthis.$store.commit('JIA',this.n)},decrement(){// commit 是操作 mutationsthis.$store.commit('JIAN',this.n)},incrementOdd(){// dispatch 是操作 actionsthis.$store.dispatch('jiaOdd',this.n)},incrementWait(){// dispatch 是操作 actionsthis.$store.dispatch('jiaWait',this.n)},},mounted() {console.log('Count',this)},}
</script><style lang="css">button{margin-left: 5px;}
</style>
http://www.yayakq.cn/news/56095/

相关文章:

  • 百度网站推广电话云南建设人才网站首页
  • 外国英文设计网站上海办公室设计装修公司
  • 在家做兼职官方网站平台wordpress 首页文章摘要
  • 公司网站空间要多大网址大全怎么卸载
  • 怎么做加盟网站苏州哪家做网站好
  • 建设网站开题报告制作一个景点的网站
  • 温州高端网站建设公司cms 网站模板
  • 网站建设 应酷特色的网站建设
  • 萍乡手机网站建设西安建设工程信息交易中心官网
  • 高端品牌建站网站备案信息更改
  • 几百块钱建网站制作电子商务网站
  • 域名服务网站建设网站ppt模板
  • 做网站除了有服务器还需要什么问题举报网站建设运行汇报
  • 公益网站建设那家好北京正规网站建设公司哪家好
  • 农家乐网站设计房产网站建网站
  • 网站服务器打不开网站建设话术关键词
  • 戴尔网站建设目标python基础教程电子版书籍
  • 北京微网站建设设计服务公司昆明网站建设一条龙服务
  • 招聘网站排行榜2021网站开发所使用的浏览器
  • 维护网站费用怎么做会计凭证云虚拟主机做视频网站
  • wordpress唯美破解主题如何做好网站推广优化
  • 电子商务等于做网站吗天元建设集团有限公司文件
  • 奉贤庄行网站建设wordpress怎么信用卡收款
  • 青岛高品质网站制作卡盟网站是怎么建设的
  • 江苏省建设网站首页创新创业教育课程网站建设方案
  • 钱包网站建设策划四川城乡住房建设厅官方网站
  • 谷城网站快速排名展厅设计搭建展位设计
  • 企业网站开发怎么样推广专员
  • 请人建网站天津做网站的
  • 建筑工程网站监理答案建筑工程网cnas