Vuex의 핵심 개념
Vuex의 핵심 개념
본문은 주로 요약하여 Vuex를 정리한다.Store 인스턴스화 중에 들어오는 객체의 속성입니다.다음store,getter,mutations,actions 속성과 같다.
// store.js
const store = Vuex.Store({
state: {
count: 0,
todos: [
{
{id: 1, done: true},
{id: 2, done: false}
}
]
},
getters: {
doneTodos: state => {
state.todos.filter(todo => todo.done)
}
},
mutations: {
increment: state => state.count++
},
actions: {
increment: context => {
context.commit('increment');
},
incrementAsync ({commit}) {
setTimeout(() => {
commit('increment');
}, 1000)
}
}
})
module.exports = store;
state,getters,mutations,actions 연계와 차이
하위 구성 요소에서state의 상태와 파생 상태를 사용합니다
// app.js
const store = require('store.js')
var app = new Vue({
components: {
com1,
com2
}
store
})
// com1.vue
{{ count }}
export default {
data () {
return {
localCount: 0
}
},
computed: {
// state
count () {
return this.$store.state.count;
}
//
doneTodos () {
return this.$store.getters.doneTodos;
}
}
}
보조 함수 mapState, mapGetters를 사용할 수도 있습니다.
// com1.vue
{{ count }}
import { mapState, mapGetters } from 'vuex';
export default {
data () {
return {
localCount: 0
}
},
computed: {
...mapState({
count: state => state.count
}),
...mapGetters({
doneTodos: getters => getters.doneTodos
})
}
}
서브어셈블리에서 state 변경
하위 구성 요소에서mutations를 제출하거나 actions를 나누어 줍니다
// com1.vue
{{ count }}
export default {
methods: {
increment () {
this.$store.commit(increment);
this.$store.dispatch(incrementAsync);
}
}
}
전재 대상:https://www.cnblogs.com/ykli/p/9565074.html
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.