Essential knowledge points for getting started with Vue
Vue summary 1.0 mainly includes Vue basic syntax, computed properties, concepts, and instructions
Vue MVVM
MVVM helps to separate the development of GUI from the development of business logic or backend logic (data model)
View layer (view layer):
In front-end development, it is usually the DOM layer. The main function is to display various information to the user, that is, the structure, layout and appearance (UI) seen.
Model layer (data layer):
The data representing the real content, the data may be fixed, but more of it is the data requested from the server.
VueModel layer (view model layer):
The view model layer is the bridge between View and Model. On the one hand, it implements Data Binding, that is, Data Binding, which reflects the changes of Model to View in real time; on the other hand, it implements DOM Listener, that is, DOM Monitoring, when DOM happens Some events (click, scroll, touch, etc.) can be monitored and the corresponding Data can be changed if necessary.
Vue template
<body>
<div id="app">
{{message}}
</div>
<script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: 'Hello'
}
})
</script>
</body>
1. Vue list display
<div id="app">
<ul>
<li v-for="item in movies">{{item}}</li>
</ul>
<script>
const app = new Vue({
el: '#app',
data: {
message: 'Hello',
movies: ['Interstellar Crossing', 'A Westward Journey', 'Youth Pi', 'Inception']
}
})
</script>
2. Counter
Just as the page directly uses the value in {{data, eg: count}}
, the tag in the body needs to use the value of data in vue directly
<h3>The current value is: {{count}}</h3>
<button @click="count++">+</button>
But in vue, methods and other data that need to use data have to add this, because there is no data in data in methods.
methods:{
add:function(){
this.count++
}
}
PS: The methods in vue cannot use the arrow function, because this does not point to the vue instance, use the arrow function to print this, and find that it is undefined
methods: {
test: () => {
console.log(this); // undefined
}
}
3. Vue directives
1. v-html
This instruction is often followed by a string type and the html in the string is parsed and rendered
<h3 v-html="message"></h3>
<script>
const app = new Vue({
el: '#app',
data: {
message: '<span>Hello</span>'
}
})
</script>
//span tag can be parsed by v-html
2. v-once
Elements and components are only rendered once and will not change as the data changes
3. v-cloak
This directive remains on the element until the associated instance finishes compiling. When used with CSS rules such as [v-cloak] { display: none }, it is possible to hide uncompiled Mustache tags until the instance is ready.
[v-cloak] {
display: none;
}
<div id="app">
<h2>{{message}}</h2> <!-- v-cloak not used -->
<h2 v-cloak>{{message}}</h2>
</div>
<script>
setTimeout(function () {
const app = new Vue({
el: '#app',
data: {
message: 'Hello'
}
})
}, 1000)
</script>
4. v-bind
(syntactic sugar :)
<img v-bind:src="imgURL" alt="">
===<img :src="imgURL" alt="">
-
v-bind dynamic binding class (dynamic binding is object)
<style> .active { color: red; } .small { font-size: 15px; } </style> </head> <body> <div id="app"> <!-- Method 1: By judging the binding class and not conflicting with the original class --> <!--<h2 v-bind:class="{class name 1: true, class name 2: false}">{{message}}</h2>--> <h2 class="small" :class="{active: isActive}">Test Text 1</h2> <!-- Attributes can be added or not quoted --> <h2 :class="{'active':isActive}">Test Text 2</h2> <!-- Method 2: Dynamic binding is placed in methods --> <h2 :class="getClasses()">Test Text 3</h2> <!-- Method 3: Dynamically bind the computed property of the returned object --> <h2 :class="getClass">Test Text 4</h2> <p></p> <button @click="btnClick">button</button> </div> <script> const app = new Vue({ el: '#app', data: { isActive: false, active: 'active', }, methods: { btnClick: function () { this.isActive = !this.isActive; }, getClasses: function () { return { active: this.isActive }; //Return active in object form: this.isActive, that is, :class="getClasses() becomes :class="{'active':isActive}" }, }, computed: { getClass: function () { return { active: this.isActive, }; }, }, }); </script> </body>
Before and after clicking the button:
-
v-bind dynamic binding class (dynamic binding is array)
<style> .active { color: red; } .small { font-size: 15px; } </style> <div id="app"> <!-- Bind several class names directly through an array --> <h2 :class="[active, small]">Test Text 1</h2> <!-- array and ternary operator --> <h2 :class="[isActive?'active':'']">Test Text 3</h2> <!-- By method binding --> <h2 class="small" :class="getClasses()">Test Text 3</h2> <p></p> <button v-on:click="btnClick">button</button> </div> <script src="../js/vue.js"></script> <script> const app = new Vue({ el: '#app', data: { active: 'active', small: 'small', isActive: false, }, methods: { btnClick: function () { this.isActive = !this.isActive; }, getClasses: function () { return [this. active]; //Return [this.active]([active]) in the form of an array, that is, :class="getClasses() is equivalently changed to: class=[active] }, }, }); </script>
5. v-on (abbreviation: @)
.once : Trigger the callback only once.
.stop : Call event.stopPropagation().
.prevent : Call event.preventDefault().
<!-- stop bubbling -->
<button @click.stop="doThis"></button>
<!-- prevent default behavior -->
<button @click.prevent="doThis"></button>
<!-- prevent default behavior, no expression -->
<form @submit.prevent></form>
@click="btnClick()
The parentheses of the v-on method can be written or not, but if the parentheses are omitted when writing the method but the method itself requires a parameter, Vue will default to the event event object produced by the browser as parameter
passed into the method
When the method is defined, if you need the event object and other parameters at the same time, you need to manually obtain the event object of the browser parameter: $event
<div id="demo">
<button @click = "btnClick('abc',$event)">button</button>
</div>
const demo = new Vue({
el:'#demo',
methods: {
btnClick: function(a, event) {
console. log(a, event);
}
}
})
6. v-if
When used with v-if, v-for has higher priority than v-if.
<h2 v-if="score>=90">Excellent</h2>
<h2 v-else-if="score>=80">Good</h2>
<h2 v-else-if="score>=60">Pass</h2>
<h2 v-else>failing</h2>
7. v-for
It is recommended to add :key=
, the main function of the key is to update the virtual DOM efficiently
Do not use non-primitive values like objects or arrays as v-for keys. Please use a string or numeric value.
<li v-for="(item,index) in names">{{item}}-{{index}}</li>
v-for="(value, name, index) in object"
8. v-model: Realize two-way binding between form elements and data
principle:
Contains two operations:
1. v-bind binds a value attribute;
2. v-on command binds the input event to the current element to update the value
<input type="text" :value="message" @input="message = $event.target.value">
v-model can also bind radio buttons and check boxes
<h2>Your hobbies are: {{hobbies}}</h2>
<label v-for="item in originHobbies" :for="item">
<input type="checkbox" :value="item" :id="item" v-model="hobbies">{{item}}
</label>
</div>
<script>
const app = new Vue({
el: '#app',
data: {
hobbies: [], // multiple selection box,
originHobbies: ['basketball', 'football', 'table tennis', 'badminton', 'billiards', 'golf']
}
})
</script>
Modifiers for v-model:
lazy modifier:
By default, v-model will synchronize the data of the input box in the input event by default, but the lazy modifier can be converted to synchronize after a custom event. Such as: update when losing focus or pressing the Enter key
<input v-model. lazy="msg">
number modifier:
By default, the input box treats the input data as a string type, and the number modifier allows the content of the input box to be automatically converted into a numeric type
<input type="number" v-model. number="age">
<h2>{{age}} {{typeof age}}</h2>
trim modifier:
Automatically filter the leading and trailing blank characters entered by the user
<input type="text" v-model. trim = "mes">
4. Vue computed properties
Note: There is no need to add () to the calculated attribute, there must be a return value
<div id="example">
<p>{{ message }}</p>
<p>{{reversedMessage }}</p>
</div>
var vm = new Vue({
el: '#example',
data: {
message: 'Hello'
},
computed: {
// getter for the computed property
reversedMessage: function () {
// `this` points to the vm instance
return this. message. split(''). reverse(). join('')
}
}
})
Computed property cache vs method
Computed properties are cached based on their reactive dependencies. They are only re-evaluated when the relevant reactive dependencies change
computed: {
now: function () {
return Date.now()
}
}
Computed properties are not updated, but in contrast, calling the method will always execute the function againwhenever a re-render is triggered**
Reason for computing property caching:
(Official website explanation) Suppose we have a computational property A with relatively high performance overhead, which needs to traverse a huge array and do a lot of calculations. Then we may have other computed properties that depend on A. Without caching, we would inevitably execute A's getter multiple times. If you don't want caching, use method instead.