The method for vue to monitor data changes in vuex: You can first obtain the data in vuex through the calculated attribute; then use watch to monitor the changes in the value of the calculated attribute, obtain the values before and after the data change, and make corresponding changes processing.
The operating environment of this tutorial: windows7 system, vue2.9.6 version, DELL G3 computer.
1. Monitor the data changes of vuex in the vue file
First obtain the data in vuex through calculated properties
Then monitor the calculated properties through watch Value to get changes
<script> import { mapGetters } from 'vuex' export default { data() { return { } }, computed: { ...mapGetters(["mapboxMap"]), mapboxMap1() { // return this.$store.state.mapbox.map; return this.mapboxMap; } }, watch: { mapboxMap1(newData, oldData) { } }, } </script>
2. How does vue monitor changes in vuex data in non-vue files?
Usually we monitor data changes in vue files, especially data changes in vuex. It is very convenient to use the watch function to get the values before and after the data change, and handle it accordingly. .
However, it is not easy when we need to monitor data changes in files such as js. Fortunately, the vue official website provides solutions
watch(fn: Function, callback: Function, options?: Object): Function
Instance method of vuex, receiving two parameters:
The first parameter is fn, listen to the return value of fn responsively, and call the callback function when the value changes. fn receives the store's state as the first parameter, and its getter as the second parameter;
The second parameter is an optional object parameter representation, similar to the callback function of vue's watch, representing the old and new values.
When we don’t want to listen, we can define a variable to receive the return value function of this method, and call this function to stop monitoring.
Advantages: We can monitor a specific value we need, and get the old and new values very conveniently like in the vue file
Disadvantages: When we need to know the changes of many values You have to write a large number of monitoring methods (you can consider encapsulating them into methods or classes)
Usage example:
/* eslint-disable */ import store from "../store/index"; const watchFun = store.watch( state => state.pathName, (newValue, oldValue) => { console.log("search string is changing"); console.log("rd: newValue", newValue); console.log("rd: oldValue", oldValue); } ); setTimeout(() => { watchFun(); }, 10000);
Introduce store into the corresponding js file
-
Call the store's watch instance method. The first function parameter returns a value in the state that needs to be monitored (for example, if I want to monitor the change of pathName in vuex, I will return this value)
The second parameter is the same as vue's watch, receiving 2 parameters representing the old and new values
-
Receive the return value of the watch through the variable watchFun, calling this method will stop monitoring
The above is how to monitor changes in vuex data in non-vue files such as js.
Just like the shortcomings mentioned in the article, when the amount of data is too large, it is unfriendly to write multiple monitors. You can consider subscribing to mutations to manage large amounts of data.
Related recommendations: "vue.js Tutorial"
The above is the detailed content of How to monitor data changes in vuex in vue. For more information, please follow other related articles on the PHP Chinese website!

Vue.js' role in web development is to act as a progressive JavaScript framework that simplifies the development process and improves efficiency. 1) It enables developers to focus on business logic through responsive data binding and component development. 2) The working principle of Vue.js relies on responsive systems and virtual DOM to optimize performance. 3) In actual projects, it is common practice to use Vuex to manage global state and optimize data responsiveness.

Vue.js is a progressive JavaScript framework released by You Yuxi in 2014 to build a user interface. Its core advantages include: 1. Responsive data binding, automatic update view of data changes; 2. Component development, the UI can be split into independent and reusable components.

Netflix uses React as its front-end framework. 1) React's componentized development model and strong ecosystem are the main reasons why Netflix chose it. 2) Through componentization, Netflix splits complex interfaces into manageable chunks such as video players, recommendation lists and user comments. 3) React's virtual DOM and component life cycle optimizes rendering efficiency and user interaction management.

Netflix's choice in front-end technology mainly focuses on three aspects: performance optimization, scalability and user experience. 1. Performance optimization: Netflix chose React as the main framework and developed tools such as SpeedCurve and Boomerang to monitor and optimize the user experience. 2. Scalability: They adopt a micro front-end architecture, splitting applications into independent modules, improving development efficiency and system scalability. 3. User experience: Netflix uses the Material-UI component library to continuously optimize the interface through A/B testing and user feedback to ensure consistency and aesthetics.

Netflixusesacustomframeworkcalled"Gibbon"builtonReact,notReactorVuedirectly.1)TeamExperience:Choosebasedonfamiliarity.2)ProjectComplexity:Vueforsimplerprojects,Reactforcomplexones.3)CustomizationNeeds:Reactoffersmoreflexibility.4)Ecosystema

Netflix mainly considers performance, scalability, development efficiency, ecosystem, technical debt and maintenance costs in framework selection. 1. Performance and scalability: Java and SpringBoot are selected to efficiently process massive data and high concurrent requests. 2. Development efficiency and ecosystem: Use React to improve front-end development efficiency and utilize its rich ecosystem. 3. Technical debt and maintenance costs: Choose Node.js to build microservices to reduce maintenance costs and technical debt.

Netflix mainly uses React as the front-end framework, supplemented by Vue for specific functions. 1) React's componentization and virtual DOM improve the performance and development efficiency of Netflix applications. 2) Vue is used in Netflix's internal tools and small projects, and its flexibility and ease of use are key.

Vue.js is a progressive JavaScript framework suitable for building complex user interfaces. 1) Its core concepts include responsive data, componentization and virtual DOM. 2) In practical applications, it can be demonstrated by building Todo applications and integrating VueRouter. 3) When debugging, it is recommended to use VueDevtools and console.log. 4) Performance optimization can be achieved through v-if/v-show, list rendering optimization, asynchronous loading of components, etc.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Atom editor mac version download
The most popular open source editor

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use