Vue local component data sharing Vue.observable() usage

Vue local component data sharing Vue.observable() usage

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 object

First, 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 components

Then 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

insert image description here

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:
  • Let's learn about Vue's life cycle
  • Detailed explanation of Vue3 life cycle hook function
  • A brief discussion on the life cycle of Vue
  • Detailed explanation of data sharing between Vue components
  • Vue implements data sharing and modification operations between two components
  • Detailed explanation of Vue life cycle and data sharing

<<:  MySQL Advanced Learning Notes (Part 3): Introduction to MySQL Logical Architecture, Detailed Explanation of MySQL Storage Engine

>>:  CentOS 6 Compile and install ZLMediaKit analysis

Recommend

mysql group by grouping multiple fields

In daily development tasks, we often use MYSQL...

Velocity.js implements page scrolling switching effect

Today I will introduce a small Javascript animati...

About installing python3.8 image in docker

Docker Hub official website 1. Search for Python ...

Architecture and component description of docker private library Harbor

This article will explain the composition of the ...

Illustration of the process of using FileZilla to connect to the FTP server

When I first started setting up an ftp server on ...

Detailed explanation of html printing related operations and implementation

The principle is to call the window.print() metho...

Implementation of React virtual list

Table of contents 1. Background 2. What is a virt...

Using CSS to implement image frame animation and curve motion

The basic principle of all animations is to displ...

JavaScript implements simple scroll window

This article example shares the specific code of ...

Detailed explanation of keywords and reserved words in MySQL 5.7

Preface The keywords of MySQL and Oracle are not ...

File upload via HTML5 on mobile

Most of the time, plug-ins are used to upload fil...

Teach you to quickly build a web cluster project based on nginx

Table of contents 1. Project Environment 2. Proje...

Introduction to TypeScript basic types

Table of contents 1. Basic types 2. Object Type 2...

Mysql uses insert to insert multiple records to add data in batches

If you want to insert 5 records into table1, the ...