As components become more detailed, you will encounter situations where multiple components share state. Vuex can certainly solve this type of problem, but as the official Vuex documentation says, if the application is not large enough, it is best not to use it to avoid cumbersome and redundant code. Today we will introduce the newly added Observable API in vue.js 2.6. By using this api, we can deal with some simple cross-component data state sharing situations. Creating a store objectFirst, create a store.js, which contains a store and a mutation, which are used to point to data and processing methods respectively. //store.js import Vue from 'vue'; export let store =Vue.observable({count:0,name:'李四'}); export let mutations={ setCount(count){ store.count=count; }, changeName(name){ store.name=name; } } Apply store objects to different componentsThen use the object in your component //obserVable.vue <template> <div> <h1>Cross-component data state sharing observable</h1> <div> <top></top> <bottom></bottom> </div> </div> </template> <script> import top from './components/top.vue'; import bottom from './components/bottom.vue'; export default { name: 'obserVable', components: top, bottom } }; </script> <style scoped> </style> //Component a <template> <div class="bk"> <span ><h1>a component</h1> {{ count }}--{{ name }} > <button @click="setCount(count + 1)">+1 in the current a component</button> <button @click="setCount(count - 1)">Current a component -1</button> </div> </template> <script> import { store, mutations } from '@/store'; export default { computed: { count() { return store.count; }, name() { return store.name; } }, methods: { setCount: mutations.setCount, changeName: mutations.changeName } }; </script> <style scoped> .bk { background: lightpink; } </style> //Component b <template> <div class="bk"> <h1>b component</h1> {{ count }}--{{ name }} <button @click="setCount(count + 1)">+1 in current b component</button> <button @click="setCount(count - 1)">Current b component -1</button> </div> </template> <script> import { store, mutations } from '@/store'; export default { computed: { count() { return store.count; }, name() { return store.name; } }, methods: { setCount: mutations.setCount, changeName: mutations.changeName } }; </script> <style scoped> .bk { background: lightgreen; } </style> Display Effect This concludes this article on the use of Vue.observable() for Vue local component data sharing. For more relevant Vue.observable() data sharing content, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future! You may also be interested in:
|
>>: CentOS 6 Compile and install ZLMediaKit analysis
In daily development tasks, we often use MYSQL...
Today I will introduce a small Javascript animati...
Docker Hub official website 1. Search for Python ...
This article will explain the composition of the ...
When I first started setting up an ftp server on ...
The principle is to call the window.print() metho...
Table of contents 1. Background 2. What is a virt...
The basic principle of all animations is to displ...
This article example shares the specific code of ...
Table of contents Generate random numbers Generat...
Preface The keywords of MySQL and Oracle are not ...
Most of the time, plug-ins are used to upload fil...
Table of contents 1. Project Environment 2. Proje...
Table of contents 1. Basic types 2. Object Type 2...
If you want to insert 5 records into table1, the ...