Home > Web Front-end > JS Tutorial > body text

Detailed interpretation of vue reconstruction technology

亚连
Release: 2018-06-09 17:59:48
Original
1854 people have browsed it

This article mainly introduces the key points and summary of Vue project reconstruction technology. Now I will share it with you and give you a reference.

Preface

I’ve been too busy recently and haven’t updated my blog for a long time. Taking a break from my busy schedule today, I would like to briefly summarize some of the technical points of the recent Vue project reconstruction.

vue data is updated, but the view is not updated

We often encounter this problem. Generally, when vue data is assigned, the vue data changes, but the view is not updated. . This is not the technical point of project reconstruction, let’s share with you the usual solution of vue2.0!

The solution is as follows:

1. Assign value through vue.set method

Vue.set(数据源, key, newValue)
Copy after login

2. Through Array.prototype.splice method

Data source.splice(indexOfItem, 1, newValue)

3. Modify the length of data

Data source.splice(newLength)

4.Mutation method

Vue.js wraps the mutation methods of the observed array, so they can trigger view updates. The wrapped methods are:

push()
pop()
shift()
unshift()
splice()
sort()
reverse()
Copy after login

prop object array application

In JavaScript, objects and arrays are reference types, pointing to the same memory space. If prop is an object or array, changing it inside a child component will affect the state of the parent component. Taking advantage of this, when we change the prop array or object in the child component, the parent component and all places where the data in the prop is applied will change. I have written an article about js deep copy and shallow copy before. If you are interested, take a look. In fact, the principles are the same.

The case is as follows:

<input class="pinput max" type="text" v-model="itemData.data.did">

<script>
export default {
 components: {
 },
 data() {
 },
 props: {
 itemData: Object
 },
 methods: {
 }
};
</script>
Copy after login

All places applied to itemData will change!

Vue will not give a warning in the console for the above change of prop. If we completely change or assign a prop, the console will give a warning! Quoting the official solution as follows:

1. Define a local variable and initialize it with the value of prop:

props: [&#39;initialCounter&#39;],
data: function () {
 return { counter: this.initialCounter }
}
Copy after login

2. Define a calculated property, process the value of prop and return:

props: [&#39;size&#39;],
computed: {
 normalizedSize: function () {
 return this.size.trim().toLowerCase()
 }
}
Copy after login

Some pitfalls of v-model

In fact, v-model and sync are some syntactic sugars. I have introduced them in articles before, and you can also find similar ones on the official website. Case!

v-model Sometimes when the data is undefined, no error will be reported, so be sure to note that v-model cannot be undefined, otherwise there will be some inexplicable problems!

Refactoring - Creation of dynamic components

Sometimes we have many similar components with only a little difference. We can write such similar components in In the configuration file, dynamically create and reference components

Method 1: Use component with is

By using reserved elements and dynamically binding their is attributes , you can dynamically switch multiple components on the same mount point:

var vm = new Vue({
 el: &#39;#example&#39;,
 data: {
 currentView: &#39;home&#39;
 },
 components: {
 home: { /* ... */ },
 posts: { /* ... */ },
 archive: { /* ... */ }
 }
})
<component v-bind:is="currentView">
 <!-- 组件在 vm.currentview 变化时改变! -->
</component>
Copy after login

Method 2: Create

<script>
export default {
 data() {
 return {
 };
 },
 render: function(createElement) {
 let _type = bi.chart.data.type;
 let _attr = bi.chart.components[_type]["attr"];
 return createElement(_attr, {
  props: {
  }
 });
 }
};
</script>
Copy after login

bi.chart.components[_type] through the render method ["attr"] This is dynamically configured in the configuration file. When type is clicked, it will change and the attr attribute under different types will be taken!

Public attribute extraction

In our projects, we often use a lot of states or data. We can extract a lot of public data and put it into an object. , we can monitor changes in this data object later. Save or obtain data.

c: {
 handler: function (val, oldVal) { /* ... */ },
 deep: true
},
// 该回调将会在侦听开始之后被立即调用
d: {
 handler: function (val, oldVal) { /* ... */ },
 immediate: true
},
Copy after login

You can use the above depth monitoring. If it needs to be executed immediately during initialization, we can use immediate execution monitoring!

require dynamic loading of dependencies

We can use the require synchronization feature to dynamically load dependencies in the code. For example, in the echart theme below, we can dynamically load it when we click to switch. !

require("echarts/theme/"+ data.theme);
Copy after login

The import loading should be placed in the head. During initialization, the default theme can be loaded with import!

The above is what I compiled for everyone. I hope it will be helpful to everyone in the future.

Related articles:

Get the value method of the default selected radio button in angularjs (detailed tutorial)

Through angularJS How to use radio to achieve one of the two options (detailed tutorial)

Comprehensive interpretation of cli in vue (detailed tutorial)

The details are Your interpretation of vue-cli 3.0 new features (detailed tutorial)

The above is the detailed content of Detailed interpretation of vue reconstruction technology. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template