目录
-
主要作用是设置标签内的文本为message
-
一般来说会用message取代标签内的所有内容
-
可以用{{message}}插值表达式代替v-text
注:message可以是文本,变量,表达式
代码演示
<div id='app'> <h2 v-text = 'message'></h2> <h3>{{message}}</h3> </div>
-
主要作用是设置标签内的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>
-
类似于逻辑结构,根据条件判断选择性的渲染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>
-
根据表达式的布尔值,通过style切换元素的display属性进行显示与隐藏
-
表达式为true则显示该节点,反之则反之
-
数据改变之后,对应元素的显示状态会同步更新
代码演示
<div id = "app"> <img src="地址" v-show="isShow"> <img src="地址" v-show="age>=18"> </div>
-
根据传入的数据生成对应的列表结构,数组经常和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>
-
为元素绑定事件,可以用简写为@,事件绑定的方法写成函数调用的形式,可传入自定义参数及事件修饰符
-
绑定的方法写在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>
-
获取和设置表单元素的值(双向数据绑定)
-
绑定的数据会和表单元素值相关联
-
绑定的数据对应表单元素的值
代码演示
<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>
-
设置元素的属性(比如: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>
-
可以解决加载Vue页面时,页面的闪烁问题
-
在使用插值表达式时,在页面没有及时地返回数据时,页面会闪烁"{{message}}"
-
需要在全局样式下添加如下样式,需要在HTML节点上添加 v-cloak 属性
CSS代码演示
[v-cloak]{ display:none; }
HTML代码演示
<div id="app" v-cloak> {{message}} </div>
-
可以跳过Vue的编译,直接显示原始值,
-
如下代码会直接显示"{{messag}}"
代码演示
<div v-pre>{{message}}</div>
-
只在第一次渲染时执行,在之后的执行中都会被当作静态内容,跳过之后所有的渲染过程
-
如下代码,开始显示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>
热门文章
- 动物医院名字有哪些(动物医院的标志是什么)
- 狗狗免费领养中心临汾(临汾狗狗收容站)
- 「3月5日」最高速度22.9M/S,2025年Shadowrocket/SSR/Clash/V2ray每天更新免费机场订阅链接
- 卖狗狗的平台微信怎么登录(卖狗狗的平台微信怎么登录不了)
- 「3月11日」最高速度20.3M/S,2025年Shadowrocket/Clash/V2ray/SSR每天更新免费机场订阅链接
- 兽用疫苗保质期多久(兽用疫苗常温下能放多久)
- 猫养小猫要多长时间(小猫养多久才能生小猫)
- [转载] Python中format函数用法
- 「3月26日」最高速度19.5M/S,2025年Shadowrocket/SSR/Clash/V2ray每天更新免费机场订阅链接
- 芜湖宠物领养中心地址(芜湖领养宠物中心官网)