Vue之v-指令

1. v-text = ‘message’

描述

  • 主要作用是设置标签内的文本为message
  • 一般来说会用message取代标签内的所有内容
  • 可以用{{message}}插值表达式代替v-text

注:message可以是文本,变量,表达式

代码演示

<div id='app'>
	<h2 v-text = 'message'></h2>
	<h3>{{message}}</h3>
</div>

2. v-html = ‘message’

描述

  • 主要作用是设置标签内的HTML结构,类似于JS中的 innerHTML
  • v-html会把字符串解析为HTML代码(区别于v-text的文本)
  • 解析文本内容使用v-text,需要解析HTML结构使用v-HTML

代码演示

<div id='app'>
	<p v-html = 'message'></p>
</div>

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>

<script>
	var app = new Vue({
    	el: "#app", 
    	data:{
			message:"<strong> 这个就是v-html</strong>"
		}
	})
</script>

3. v-if & v-else-if& v-else

描述

  • 类似于逻辑结构,根据条件判断选择性的渲染DOM结构
  • 表达式为true则渲染该节点的DOM结构,反之则反之
  • 频繁切换可以用v-show,减小切换损耗

代码演示

<div id = "app">
    <p v-if="isShow">我是一个p标签</p>
    <p v-else-if="表达式">我是一个p标签</p>
    <p v-else">我是一个p标签</p>
</div>

4. v-show

描述

  • 根据表达式的布尔值,通过style切换元素的display属性进行显示与隐藏
  • 表达式为true则显示该节点,反之则反之
  • 数据改变之后,对应元素的显示状态会同步更新

代码演示

<div id = "app">
    <img src="地址" v-show="isShow">
    <img src="地址" v-show="age>=18">
</div>

5. v-for

描述

  • 根据传入的数据生成对应的列表结构,数组经常和v-for结合使用
  • 语法是==v-for="(item,index) in List"== 或 ==v-for=“item in List”==,其中item代表每一项,index代表索引
  • 数组长度的更新会同步到页面上,是响应式的

代码演示

<div id="app">
	<ul>
    	<li v-for="item in arr">元素:{{item}}</li>
    	<h2 v-for="(item,index) in student">{{index}}.{{item.name}}</h2>
	</ul>
</div>

6. v-on

描述

  • 为元素绑定事件,可以用简写为@,事件绑定的方法写成函数调用的形式,可传入自定义参数及事件修饰符
  • 绑定的方法写在methods属性中,方法内部可以通过this关键字访问data中的数据
  • 事件的后面跟上修饰符,可以对事件进行限制,事件修饰符有多种,.enter 可以限制触发的按键为回车

代码演示

<div id = "app">
    <input type="button" @click="doIt('nb',666)"
    <input type="text" @keyup.enter="sayHi";
</div>

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>

<script>
	var app = new Vue({
   	 	el: "#app",
    	methods:{
			doIt:function(p1,p2){}
			sayHi:function(){}
		}
	})
</script>

7. v-model

描述

  • 获取和设置表单元素的值(双向数据绑定)
  • 绑定的数据会和表单元素值相关联
  • 绑定的数据对应表单元素的值

代码演示

<div id = "app">
    <input type="text" v-model="message">
</div>

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>

<script>
	var app = new Vue({
    	el: "#app", 
    	data:{
			message:"这就是input标签的value值"
		}
	})
</script>

8. v-bind

描述

  • 设置元素的属性(比如:src,title,class),
  • 完整格式为:==v-bind:属性名 = 表达式==,简写的话可以直接省略v-bind,只保留 :属性名
  • 需要动态的增删class建议使用对象的方式

代码演示

<div id = "app">
    <img v-bind:src="imgSrc">  //正常格式
    <img :src="imgSrc"> //简写格式
    <img :src="imgSrc" :class="{active:isActive}"> //对象的方式增删class
</div>

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>

<script>
	var app = new Vue({
    	el: "#app", 
    	data:{
			imgSrc:图片地址,
			isActive:false
		}
	})
</script>

9. v-cloak

描述

  • 可以解决加载Vue页面时,页面的闪烁问题
  • 在使用插值表达式时,在页面没有及时地返回数据时,页面会闪烁"{{message}}"
  • 需要在全局样式下添加如下样式,需要在HTML节点上添加 v-cloak 属性

CSS代码演示

[v-cloak]{
	display:none;
}

HTML代码演示

<div id="app" v-cloak>
  {{message}}
</div>

10. v-pre

描述

  • 可以跳过Vue的编译,直接显示原始值,
  • 如下代码会直接显示"{{messag}}"

代码演示

<div v-pre>{{message}}</div>

11. v-once

描述

  • 只在第一次渲染时执行,在之后的执行中都会被当作静态内容,跳过之后所有的渲染过程
  • 如下代码,开始显示1,点击后显示2,再次点击不会改变前端页面数值

代码演示

<div id = "app">
	<h1>{{cnt}}</h1>
    <button @click='cnt++'>点我cnt+1</button>
</div>

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>

<script>
	var app = new Vue({
    	el: "#app", 
    	data:{
			cnt=1
		}
	})
</script>