VUE的10个常用指令

news2025/8/9 23:44:40
01 v-once
说明: 只渲染元素和组件 一次 。随后的重新渲染,元素 / 组件及其所有的子节点将被视为静态内容并跳过。这可以用于优化更新性能。
<!-- 单个元素 -->
<span v-once>This will never change: {{msg}}</span>
<!-- 有子元素 -->
<div v-once>
<h1>comment</h1>
<p>{{msg}}</p>
</div>
<!-- 组件 -->
<my-component v-once :comment="msg"></my-component>
<!-- `v-for` 指令 -->
<ul>
<li v-for="i in list" v-once>{{i}}</li>
</ul>

 

02 v-text
说明: v-text 指令用于更新标签包含的文本,它的作用跟双大括号的效果一样
<span v-text="msg"></span>
<!-- 和下面的一样 -->
<span>{{msg}}</span>
03 v-html
说明: 帮助我们绑定一些包含 html 代码的数据在视图上,比如: “<b>hello,vue</b>” ,这个字符串包含了<b> 标签,要想 <b> 不被当作普通的字符串渲染出来,就得用 v-html
说明: <div v-html="html"></div>

 

04 v-show
说明: v-show 指令的取值为 true/false ,分别对应着显示 / 隐藏它就是用来控制元素的 display css
性的 [display:none]
<div id="app">
<p v-show="show1"> 我是 true</p>
<p v-show="show2"> 我是 false</p>
</div>
<script>
let app = new Vue({
el:"#app",
data:{
show1:true,
show2:false }
});
</script>
渲染后

 

05 v-if
说明: 设置为 true 的标签,成功渲染出来,而设置为 false 的标签,直接被一行注释代替了,并没有
被解析渲染出来。
v-show v-if 两者的区别
如果需要 频繁切换显示 / 隐藏 的,就用 v-show
如果运行后 不太可能切换显示 / 隐藏 的,就用 v-if
<p v-if="if_1"> 我是 true</p>
<p v-if="if_2"> 我是 true</p>
let app = new Vue({
el:"#app",
data:{
if_1:true,
if_2:false
}
});
06  v-else
说明: 两个标签 : 第一个使用 v-if 指令,并取值为 false ,第二个使用 v-esle 指令 , 一旦第一个标签的
v-if 指令的值为 true ,被忽视的就是第二个 <p> 标签了。 v-if v-else 只有一个会被渲染出来。
<div v-if="Math.random() > 0.5">
Now you see me
</div>
<div v-else>
Now you don't
</div>

 

07 v-else-if:
用法同 js 原生中的 if…elseif…elseif…else
<div id="app">
<input type="text" v-model="type" />
<p v-if="type === 'A'">
A
</p>
<p v-else-if="type === 'B'">
B
</p> <p v-else-if="type === 'C'">
C
</p>
<p v-else>
Not A/B/C
</p>
</div>
<script>
var vm=new Vue({
el:"#app",
data:{
type:""
}
})
</script>
08  v-for
说明: 我们用 v-for 指令根据一组数组 / 对象的选项列表进行渲染。 v-for 指令需要使用 item in items
式的特殊语法, items 是源数据数组并且 item 是数组元素迭代的别名。
08-1 基本用法
<ul>
<li v-for=" item in items ">{{item}}</li>
</ul>
data: {
items : [' ', ' ', ' ', ' ']
}
08-2 v-for 应用于数组
<div v-for="(item,index) in list">
{{index}}.{{item}}
</div>
data:{
list:['Tom','John','Lisa']
}
08-3 v-for 应用于对象
<div v-for="(item,index) in list">
{{index}}.{{item}}
</div>
data:{
list:['Tom','John','Lisa']
}
Eg2:

 

 

let vm = new Vue({
el:"#app",
data:{
list:[
{id:1,name:"a"},
{id:2,name:"b"},
{id:3,name:"c"},
{id:4,name:"d"},
{id:5,name:"e"},
{id:6,name:"f"}
],
id:"",
name:""
},
methods:{
add(){
this.list.push({id:this.id,name:this.name})
}
}
})

 

09  v-bind
<!-- 绑定一个属性 -->
<img v-bind:src="imgUrl" />
<!-- 缩写 -->
<img :src="imgUrl" />
<!-- 内联字符串拼接 -->
<img :src="'../images/' + fileName" />
<!-- class 绑定 -->
<div :class="{ 'red' : isRed}"></div> 布尔值绑定模式 对象方式
<span v-bind:class="{'class-a': isA ,'class-b': isB }">VUE</span>
var vm = new Vue({
el: "#demo",
data: {
isA : true, isB : true
}
})
<div :class="[classA, classB]"></div> 变量绑定模式:数组绑定
<span :class=[ classA ,classB]>VUE</span>
var vm = new Vue({
el: "#demo",
data: {
classA : "class-a",
classB: "class-b"
}
})
<div :class="[classA, {‘classB’: isB, ‘classC’: isC}, classD]"></div> 综合绑定模式
<span :class="[one,{'classA':classa,'classB':classb}]">Be good at VUE</span>
var vm = new Vue({
el: "#demo",
data: {
one: "string", // string--> 类名
classa: true,
classb: false
}
})
<!-- style 绑定 -->
<div :style="{fontSize: size + 'px'}">div</div> 内嵌绑定
<div v-bind:style="{width:'200px', height:'200px', 'background-color':'red',fontSize: size + 'px'}">
new Vue({
el: "#app",
data: {
size:60
}
})
<div v-bind:style="styleObject"></div> 直接绑定到一个样式对象
<!-- 绑定一个有属性的对象 -->
<div v-bind="{id:someProp, 'other-attr': otherProp}"></div>
<span v-bind:style="styleObject">VUE</span>
data: {
styleObject: {
color: 'red',
fontSize: '13px'
}
}
<!-- 通过 prop 绑定,
prop 必须在 my-component 中声明 -->
<my-component :prop="someThing"></my-component>
<!-- 通过 $props 将父组件的 props 一起传递给子组件 -->
<child-component v-bind="$props"></child-component>
<!-- Xlink -->
<svg><a :xlink:special="foo"></a></svg>
10 v-on
作用:
用在普通元素上时,只能监听 原生 DOM 事件 。用在自定义元素组件上时,也可以监听子组件触发的 自定义事件
修饰符:
. stop - 调用 event.stopPropagation()
. prevent - 调用 event.preventDefault()
. capture - 添加事件侦听器时使用 capture 模式。
. self - 只当事件是从侦听器绑定的元素本身触发时才触发回调。
. { keyCode | keyAlias } - 只当事件是从特定键触发时才触发回调。
. native - 监听组件根元素的原生事件。
. once - 只触发一次回调。
. left - (2.2.0) 只当点击鼠标左键时触发。
. right - (2.2.0) 只当点击鼠标右键时触发。
. middle - (2.2.0) 只当点击鼠标中键时触发。
. passive - (2.3.0) { passive: true } 模式添加侦听器
API: https://v2.cn.vuejs.org/v2/api/?#v-on

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/34001.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

二进制逻辑运算和基本门电路

目录 基本门电路很重要&#xff0c;做内存扩展片选译码的时候会常用 一&#xff1a;逻辑非&#xff08;按位取反&#xff09; not 二&#xff1a;逻辑乘&#xff08;逻辑与&#xff09;按位求“与” 有零出零 and 三&#xff1a;逻辑或&#xff08;逻辑加) 有1出1 …

2023-2028年中国化工新材料行业发展前景与投资趋势分析报告

本报告由锐观咨询重磅推出&#xff0c;对中国化工新材料行业的发展现状、竞争格局及市场供需形势进行了具体分析&#xff0c;并从行业的政策环境、经济环境、社会环境及技术环境等方面分析行业面临的机遇及挑战。还重点分析了重点企业的经营现状及发展格局&#xff0c;并对未来…

JavaScript高级复习下(60th)

1、函数内 this 的指向 2、严格模式 1、什么是严格模式 JavaScript 除了提供正常模式外&#xff0c;还提供了 严格模式&#xff08;strict mode&#xff09;。ES5 的严格模式是采用具有限制性 JavaScript 变体的一种方式&#xff0c;即在严格的条件下运行 JS 代码。 严格模式…

说一下 ArrayDeque 和 LinkedList 的区别?

大家好&#xff0c;我是小彭。 在上一篇文章里&#xff0c;我们聊到了基于链表的 Queue 和 Stack 实现 —— LinkedList。那么 Java 中有没有基于数组的 Queue 和 Stack 实现呢&#xff1f;今天我们就来聊聊这个话题。 小彭的 Android 交流群 02 群已经建立啦&#xff0c;扫描…

APP到底有没有权限-恶意拷贝删除照片

作者&#xff1a;黑蛋 近期发生了一件比较恶劣的事情&#xff0c;某客户在某物上面买了一件东西&#xff0c;但是这个东西是假货&#xff0c;所以客户致电某物人工客服&#xff0c;并进行了录音&#xff0c;这时候某物试图通过自身的客户端软件&#xff0c;去删除客户手机上的…

DFP 数据转发协议应用实例 7.使用 DLS1x 与 VSxxx 设备的 LoRA 匹配

DFP 数据转发协议应用实例 7.使用 DLS1x 与 VSxxx 设备的 LoRA 匹配 DFP 是什么&#xff1f; 稳控科技编写的一套数据转发规则&#xff0c; 取自“自由转发协议 FFP&#xff08;Free Forward Protocol&#xff09;” &#xff0c;或者 DFP&#xff08;DoubleF Protocol&#x…

维格云单点登录SSO入门教程

功能简介 无代码维格云单点登录功能支持用户通过配置,将无代码维格云的帐号体系,和提供标准OAuth2.0认证服务系统、LDAP的帐号体系统一起来。 两种单点登录方式的配置见子文档:OAuth 2.0LDAP,本文只描述通用功能:全局单点登录、退出登录后跳转指定页面。 注:本功能为A…

ArcGIS综合制图教程,简单上手!

目的 1、了解专题地图组成的各个要素&#xff1b; 2、掌握ArcGIS编辑专题图的方法和步骤&#xff1b; 实习内容 使用ArcGIS生成1&#xff1a;200万比例尺的浙江省县级行政区划图&#xff0c;并输出成像文件。 实习步骤 一、将ArcGIS切换到Layout视图&#xff0c;并调整页面…

HTML、CSS学习笔记小结

目录 1&#xff0c;HTML 1.1 简单介绍 1.2 快速入门 1.3 基础标签 代码演示&#xff1a; 1.4 图片、音频、视频标签 代码演示&#xff1a; 1.5 超链接标签 代码演示&#xff1a; 1.6 列表标签 代码演示&#xff1a; 1.7 表格标签 代码演示&#xff1a; 1.8 布局标…

【LeetCode与《代码随想录》】哈希表篇:做题笔记与总结-JavaScript版

文章目录代码随想录主要题目242. 有效的字母异位词349. 两个数组的交集202. 快乐数1. 两数之和&#xff08;经典哈希&#xff09;454. 四数相加 II15. 三数之和&#xff08;双指针&#xff09;18. 四数之和&#xff08;双指针&#xff09;相关题目383. 赎金信49. 字母异位词分组…

【构建ML驱动的应用程序】第 9 章 :选择部署选项

&#x1f50e;大家好&#xff0c;我是Sonhhxg_柒&#xff0c;希望你看完之后&#xff0c;能对你有所帮助&#xff0c;不足请指正&#xff01;共同学习交流&#x1f50e; &#x1f4dd;个人主页&#xff0d;Sonhhxg_柒的博客_CSDN博客 &#x1f4c3; &#x1f381;欢迎各位→点赞…

Redis基础命令(set类型)交集并集差集

目录 概述: 特征&#xff1a; Set常见命令&#xff1a; 1.Sadd key number..&#xff1a;向set中添加一个或多个元素 2.Srem key number...&#xff1a;移除set中指定的元素 3.Scard key&#xff1a;返回set中元素的个数 4.Sismember key member&#xff1a;判断一个元素…

liunx中如何启动redis

连上服务器之后&#xff0c;这个“~”’波浪符号应该是在root目录下&#xff0c;我们需要到这个目录的外面&#xff0c;根目录 root目录 目录的外面&#xff0c;根目录 cd .. 变为"/"符号即可 然后再找到redis的安装目录&#xff0c;也可以在xftp中找&#xff0c;可视…

【LeetCode每日一题】——90.子集 II

文章目录一【题目类别】二【题目难度】三【题目编号】四【题目描述】五【题目示例】六【解题思路】七【题目提示】八【时间频度】九【代码实现】十【提交结果】一【题目类别】 数组 二【题目难度】 中等 三【题目编号】 90.子集 II 四【题目描述】 给你一个整数数组 num…

有没有把语音转为文字的软件?这几个转换软件你值得收藏

我们在日常的工作和生活中&#xff0c;应该经常会遇到需要将音频转换成文字的情况吧。相信大部分的小伙伴都会选择直接使用转换软件进行音频转文字的操作&#xff0c;但在使用的过程中就会发现&#xff0c;有些软件会在使用次数、音频时长上面有所限制&#xff0c;导致我们会转…

【文件格式_XML_HTML_】XML、HTML文件

HTML xml what&#xff1f; XML是被设计用来存储数据、携带数据和交换数据的&#xff0c;通过XML&#xff0c;可以在不兼容的系统之间交换数据&#xff0c;利用XML&#xff0c;纯文本文件可以用来存储数据。在不使用XML时&#xff0c;HTML用于显示数据&#xff0c;数据必须存…

python面向对象(上)

python面向对象上命名规则对象的创建创建类对象创建实例对象修改增加类属性构造方法构造实例方法不带变量带变量构造方法小例子构造类方法构造静态方法运算符的重载比较运算符重载字符串重载索引或切片重载索引或切片重载检查成员重载重载小结持续更新中~~~~~~~~先上个例子&…

莫名其妙: conda使用过程各种错误及总结

conda真的很烦呢&#xff0c;有啥好用的&#xff0c;要不是准备学习一下虚拟环境&#xff0c;我才不折腾呢&#xff0c;浪费好多时间&#xff0c;(&#xff1b;′⌒) 不要挂代理&#xff0c;我怎么知道为什么&#xff0c;和pip一样&#xff0c;不过后来不知道为什么pip很流畅c…

知识蒸馏(Knowledge Distillation)

0.Introduction 知识蒸馏&#xff08;Knowledge Distillation&#xff0c;简记为 KD&#xff09;是一种经典的模型压缩方法&#xff0c;核心思想是通过引导轻量化的学生模型“模仿”性能更好、结构更复杂的教师模型&#xff08;或多模型的 ensemble&#xff09;&#xff0c;在…

第3章:中文本文向量化——代码详解

1.单条语句的向量化 根据不同的向量化&#xff0c;对“中华女子学院&#xff1a;本科层次仅1专业招男生”这句话进行向量化 1.1 One-hot方法 # one-hot代码 import jieba import os import numpy as npstopwords open(./data/哈工大停用词表.txt).read().split("\n&qu…