vue3笔记 provide/inject与vuex及运用插件持久化存储

provide/inject

1.父组件

vue3笔记 provide/inject与vuex及运用插件持久化存储_第1张图片

 子组件

vue3笔记 provide/inject与vuex及运用插件持久化存储_第2张图片

 孙组件

vue3笔记 provide/inject与vuex及运用插件持久化存储_第3张图片

数据是响应式的,一旦某个组件数据发生改变,另外引用的组件也会发生改变 

总结:

vue3笔记 provide/inject与vuex及运用插件持久化存储_第4张图片

vuex

首先安装vuex插件 npm install vuex

vue3笔记 provide/inject与vuex及运用插件持久化存储_第5张图片

在store下面的index.js里

import {createStore} from "vuex"
export default createStore({
	state:{
		num:10,
		sum:20
	},
	getters:{
    total(state){
		return state.num+state.sum
	}
	},
	mutations:{
		changeNum(state,val){
			state.num=val
		}
	},
	actions:{
		changeBtn(){
			alert('1')
		}
	}
})

在组件中调用修改等




vue3笔记 provide/inject与vuex及运用插件持久化存储_第6张图片

modules模块划分,和vue2写法一样

vue3笔记 provide/inject与vuex及运用插件持久化存储_第7张图片

 user.js里

export default{
    state:{
        userInfo:'info'
    },
    mutations:{
        changeInfo(state){
        state.userInfo="123"
        }
    }
}

index.js里

import {createStore} from "vuex"
import user from './modules/user'
export default createStore({
modules:{
	user
},
})

引入vuex见上面写法

A组件




运用插件持久化存储

npm i vuex-persistedstate -S

在index.js里

import {createStore} from "vuex"
import persistedState from 'vuex-persistedstate'
import user from './modules/user'
export default createStore({
modules:{
	user
},
plugins:[persistedState({
	key:"xiaoyang",
	paths:['user']  //需要存储的参数
})]
})

你可能感兴趣的:(前端,javascript,vue.js)