mustache是胡须的意思,因为{{}}
像胡须,又叫大括号语法。
在vue对象挂载的dom元素中,{{}}
不仅可以直接写变量,还可以写简单表达式。
- <div id="app">
-
- <h2>{{name}}h2>
-
- <h2>{{count>5? "4": "5" }}h2>
- <h2>{{4+3}}h2>
-
- div>
- <script>
- const vm = new Vue({
- el: '#app',
- data() {
- return {
- name: '张三',
- count: 10
-
- }
- }
- })
- script>
v-once表示该dom元素只渲染一次,之后数据改变,不会再次渲染。(也就是再次修改修改值时,页面不会渲染)
- <div id="app">
-
- <h2>{{name}}h2>
-
- <h2 v-once>{{name}}h2>
- div>
- <script>
- const vm = new Vue({
- el: '#app',
- data() {
- return {
- name: '张三'
-
-
- }
- }
- })
- script>
上述{{name}}
的name修改后,第一个h2标签数据会自动改变,第二个h2不会
在某些时候我们不希望直接输出百度一下
这样的字符串,而输出被html自己转化的超链接。此时可以使用v-html。它是能够识别标签的,但是它会把所在标签的内容给覆盖
- <body>
- <div id="app">
- <h2 v-html="src">12334h2>
- div>
- <script>
- const vm = new Vue({
- el: '#app',
- data() {
- return {
- src: "百度一下"
- }
- }
- })
- script>
12334被覆盖了
v-text会覆盖dom元素中的数据,相当于js的innerText方法。不能识别标签
- <div id="app">
- <h2 v-text="src">12334h2>
- div>
- <script>
- const vm = new Vue({
- el: '#app',
- data() {
- return {
- src: "百度一下"
- }
- }
- })
- script>
有时候我们期望直接输出{{name}}
这样的字符串,而不是被{{}}
语法转化的name的变量值,此时我们可以使用v-pre
标签。
- <div id="app">
- <h2 v-pre>{{name}}h2>
- div>
- <script>
- const vm = new Vue({
- el: '#app',
- data() {
- return {
- name:'张三'
- }
- }
- })
有时候因为加载延时问题,例如卡掉了,数据没有及时刷新,就造成了页面显示从{{message}}
到message变量“你好啊”的变化,这样闪动的变化,会造成用户体验不好。此时需要使用到v-cloak
的这个标签。在vue解析之前,div属性中有v-cloak
这个标签,在vue解析完成之后,v-cloak标签被移除。简单,类似div开始有一个css属性display:none;
,加载完成之后,css属性变成display:block
,元素显示出来。
- html>
- <html lang="en">
-
- <head>
- <meta charset="UTF-8">
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
- <meta http-equiv="X-UA-Compatible" content="ie=edge">
- <title>v-cloak指令的使用title>
- <style>
- [v-cloak]{
- display: none;
- }
- style>
- head>
-
- <body>
- <div id="app" v-cloak>
- <h2>{{message}}h2>
- div>
- <script src="https://cdn.jsdelivr.net/npm/vue@2.6.10/dist/vue.js">script>
- <script>
- //在vue解析前,div中有一个属性cloak
- //在vue解析之后,div中没有一个属性v-cloak
- setTimeout(() => {
- const app = new Vue({
- el: "#app",
- data: {
- message: "你好啊"
- }
- })
- }, 1000);
- script>
- body>
-
- html>
这里通过延时1秒模拟加载卡住的状态,结果一开始不显示message的值,div元素中有v-cloak的属性,1秒后显示message变量的值,div中的v-cloak元素被移除。