Detailed explanation of Vue's simple store

Detailed explanation of Vue's simple store

The simplest application of store in Vue is global storage.

I use two components here to jump to each other ( Helloworld.vue and twopage.vue ). The former is used to put data into the store, and the latter is used to get data from the store.

First you need to install vuex: npm install vuex --save ;

Because you need to jump, you have to install the router: npm install vue-router --save

Create a new store folder and create a new modules folder, getters.js and index.js in it;

Create mystate.js in modules

insert image description here

Put our variable msg in mystate:

const state = {
    msg: 'This is my status',
}
export default {
    state
}

Getters hold the key-value pairs of the variables we operate on:

const getters = {
    msg:state => state.mystate.msg,
}
export default getters

Index is used to configure and create vuex.store :

import Vue from 'vue'
import Vuex from 'vuex'
import getters from './getters'
Vue.use(Vuex)
// https://webpack.js.org/guides/dependency-management/#requirecontext
const modulesFiles = require.context('./modules', true, /\.js$/)
// It will automatically require all vuex modules in your module file // you do not need `import app from './modules/app'`
// it will auto require all vuex modules from modules file
const modules = modulesFiles.keys().reduce((modules, modulePath) => {
  // set './app.js' => 'app'
  const moduleName = modulePath.replace(/^\.\/(.*)\.\w+$/, '$1')
  const value = modulesFiles(modulePath)
  modules[moduleName] = value.default
  return modules
}, {})
const store = new Vuex.Store({
  modules,
  getters,
})
export default store

You need to call store and router in the vue instance of main.js (the routes of the two pages are later):

import Vue from 'vue'
import Vuex from 'vuex'
import getters from './getters'
Vue.use(Vuex)
// https://webpack.js.org/guides/dependency-management/#requirecontext
const modulesFiles = require.context('./modules', true, /\.js$/)
// It will automatically require all vuex modules in your module file // you do not need `import app from './modules/app'`
// it will auto require all vuex modules from modules file
const modules = modulesFiles.keys().reduce((modules, modulePath) => {
  // set './app.js' => 'app'
  const moduleName = modulePath.replace(/^\.\/(.*)\.\w+$/, '$1')
  const value = modulesFiles(modulePath)
  modules[moduleName] = value.default
  return modules
}, {})
const store = new Vuex.Store({
  modules,
  getters,
})
export default store

Configure two routes in index.js under router :

import Vue from 'vue'
import Vuex from 'vuex'
import getters from './getters'
Vue.use(Vuex)
// https://webpack.js.org/guides/dependency-management/#requirecontext
const modulesFiles = require.context('./modules', true, /\.js$/)
// It will automatically require all vuex modules in your module file // you do not need `import app from './modules/app'`
// it will auto require all vuex modules from modules file
const modules = modulesFiles.keys().reduce((modules, modulePath) => {
  // set './app.js' => 'app'
  const moduleName = modulePath.replace(/^\.\/(.*)\.\w+$/, '$1')
  const value = modulesFiles(modulePath)
  modules[moduleName] = value.default
  return modules
}, {})
const store = new Vuex.Store({
  modules,
  getters,
})
export default store

Use the route view in App.vue:

<template>
  <div id="app">
   <router-view></router-view>
  </div>
</template>
<script>
export default {
  name: 'App'
}
</script>
<style>
#app {
  font-family: 'Avenir', Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

Finally, there are two page components, HelloWorld.vue :

Two-way binding and monitoring of msg, putting the new value of msg into the global variable.

The method for monitoring triggering is setstate;

sessionStorage.setItem('msg', value) is used to put the value of value into the value corresponding to the key called msg, which is the key-value pair stored in getters.js .

<template>
  <div class="hello">
    <img src="../assets/logo.png" />
    <br />
    <input v-model="msg"/>
    <h2>{{ msg }}</h2>
    <router-link to="/two">I want to go to the second page</router-link>
  </div>
</template>
<script>
export default {
  name: "HelloWorld",
  data() {
    return {
      msg: "Welcome to new vue project",
    };
  },
  methods: {
    setstate(value) {
      sessionStorage.setItem('msg', value);
    },
  },
  watch:
    msg(newName, oldName) {
      this.setstate(newName);
    },
  },
};
</script>
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
a {
  color: #42b983;
}
</style>

In the second page component twopage.vue , you need to take out the stored msg:

sessionStorage.getItem('msg') gets the value corresponding to the msg key.

<template>
  <div>
    This is the second page<h2>{{ msg }}</h2>
    <router-link to="/">I want to go back</router-link>
  </div>
</template>

<script>
export default {
  data() {
    return {
      msg: "",
    };
  },
  methods: {
    setmsg() {
        this.msg = sessionStorage.getItem('msg');
    },
  },
  created(){
      this.setmsg()
  }
};
</script>

Directory structure:

insert image description here

Demo:

Initial state:

insert image description here

To change the content of the input box:

insert image description here

Go to the second page:

insert image description here

Summarize

This article ends here. I hope it can be helpful to you. I also hope that you can pay more attention to more content on 123WORDPRESS.COM!

You may also be interested in:
  • Detailed explanation of the use of store in vuex in vue.js state management
  • Detailed explanation of monitoring changes in variables defined in $store in Vue components
  • Detailed explanation of two ways of vuex data transmission and the solution to this.$store undefined
  • Detailed explanation of the modular splitting practice of Store under Vuex
  • Detailed explanation of vuex store source code

<<:  Steps to build MHA architecture deployment in MySQL

>>:  Nginx Service Quick Start Tutorial

Recommend

About the processing of adaptive layout (using float and margin negative margin)

Adaptive layout is becoming more and more common i...

What is Software 404 and 404 Error and what is the difference between them

First of all, what is 404 and soft 404? 404: Simpl...

Vue-Router installation process and principle detailed

Table of contents 1. Front-end routing implementa...

Analysis of MySQL duplicate index and redundant index examples

This article uses examples to describe MySQL dupl...

HTML table layout example explanation

The elements in an HTML document are arranged one...

SSM implements the mysql database account password ciphertext login function

introduction Our company is engaged in the resear...

Application of anchor points in HTML

Set Anchor Point <a name="top"><...

Tutorial diagram of installing CentOS and Qt in Vmware virtual machine

Vmware Installation Installing Packages Download ...

MySQL slow query pt-query-digest analysis of slow query log

1. Introduction pt-query-digest is a tool for ana...

How does JS understand data URLs?

Table of contents Overview Getting started with d...

Docker commands are implemented so that ordinary users can execute them

After installing docker, there will usually be a ...