State and reactivity in Vue

栏目: IT技术 · 发布时间: 5年前

内容简介:In one of myprevious articles, I mentioned how it is possible to design a simple state manager in Vue by usingIn Vue 2, a reactive store might look like this:We can provide the components with a basic

In one of myprevious articles, I mentioned how it is possible to design a simple state manager in Vue by using observable . The Observable API has been available in Vue since version 2 however, with version 3 the reactive object is no longer directly modified but proxied into. Let's have a look how both work in detail:

In Vue 2, a reactive store might look like this:

// store.js
export const store = Vue.observable({ orders: 0 });

We can provide the components with a basic dispatch function that will collect an action with a payload and that will take care of updating the state. Also, we might want to provide a getters helper so that the store values can be reached as computed properties:

// store.js
export function dispatch(type, payload) {
    switch(type) {
        case 'increment-orders':
            Object.assign(store, { orders: store.orders + payload });
            break;
        default:
            //
    }
}

export function getters(orders) {
    return {
        orders: () => store.orders
    }
}

In our Vue component, we register the getters and use dispatch to notify the store about a user event:

<template>
    I have {{ orders }} orders on my account. 
    <a @click="increment()">add order</a>
</template>

<script>
import { dispatch } from 'store';

return {
    computed: { ...getters() },
    methods: { 
        increment() {
            dispatch('increment-orders', 1); 
        } 
    }
};
</script>

Vue 3 and the Composition API

With the introduction of the Composition API , operating with reactive properties is much simpler. The above example could be easily refactored to follow the new constructs. Here, reactive replaced the functionaltiy that observable was providing:

// store.js
import { reactive } from 'vue';

export const store = reactive({ orders: 0 });

// Component.vue
import { store, dispatch } from './store';

export default {
    setup() {
        return { store };
    },
    methods:{
        increment() {
            dispatch('increment-orders', 1);
        }
    }
}

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Python 3面向对象编程

Python 3面向对象编程

[加]Dusty Phillips(达斯帝•菲利普斯) / 肖鹏、常贺、石琳 / 电子工业出版社 / 2015-6 / 79.00元

Python 是一种面向对象的解释型语言,面向对象是其非常重要的特性。《Python 3面向对象编程》通过Python 的数据结构、语法、设计模式,从简单到复杂,从初级到高级,一步步通过例子来展示了Python 中面向对象的概念和原则。 《Python 3面向对象编程》不是Python 的入门书籍,适合具有Python 基础经验的开发人员阅读。如果你拥有其他面向对象语言的经验,你会更容易理解......一起来看看 《Python 3面向对象编程》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具