【Vue入门】语法 —— 插值、指令、过滤器、计算属性、监听器

目录

一、模版语法

1.1 插值

1.1.1 文本

1.1.2 html解析

1.1.3 属性

1.1.4 表达式

1.2 指令

1.2.1 核心指令

1.2.3 动态参数

二、过滤器

2.1 局部过滤器

2.2 全局过滤器

三、计算属性

四、监听器

五、排座案例

小结:计算属性和监听属性的区别


一、模版语法

1.1 插值

        Vue.js 使用了基于 HTML 的模板语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据。所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器和 HTML 解析器解析。vue将模板编译成虚拟dom,结合响应系统,Vue 能够智能地计算出最少需要重新渲染多少组件,并把 DOM 操作次数减到最少。

html模板语法: 这是一种基于字符串的模板技术,以字符串和数据为输入,通过用正则表达式将占位符替换为所需数据的方式,构建出完整的 HTML 字符串。

1.1.1 文本

        直接使用{{xxx}}的形式,标签将会被替换成为数据对象(data)上xxx属性值,当绑定的数据对象上的xxx属性值发生变化时,插值处的值也会发生变化(双向绑定

<div id="xw">
       {{msg}}
</div>

1.1.2 html解析

如果要输出html格式的数据,需要使用v-html指令。

<!DOCTYPE html>
<html><head><meta charset="utf-8" /><title>html解析</title><!-- 1.导入工具 --><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script><script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script></head><body><!-- 2.定义边界 --><div id="xw"><div v-html="htmlstr"></div></div><!-- 3.构建vue实例并绑定边界 --><script>new Vue({el: "#xw",data() {return {htmlstr: '<h3 style="color:blue;">这是一个html片段</h3>'}}})</script></body>
</html>

1.1.3 属性

HTML属性中的值应使用v-bind指令。类型与jQuery中的$("#xxx").attr(Name,Val)

<!DOCTYPE html>
<html><head><meta charset="utf-8" /><title>html解析</title><!-- 1.导入工具 --><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script><script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script><style>.blueClass{font-size: 30px;color: skyblue;}</style></head><body><!-- 2.定义边界 --><div id="xw"><p v-bind:class="hontColor">哈哈</p></div><!-- 3.构建vue实例并绑定边界 --><script>new Vue({el: "#xw",data() {return {hontColor:"blueClass",}}})</script></body>
</html>

也可以这样写:

//在html使用v-bind:style指令设置样式
<p v-bind:style="color">哈哈</p>
data() {return {//定义一个属性,其值为所需样式color:"color: yellowgreen;"}
}

1.1.4 表达式

 Vue提供了完全的JavaScript表达式支持:

  • {{str.substr(0,3)}}
  • {{ number + 1 }}
  • {{ ok ? 'YES' : 'NO' }}
  • <li v-bind:id="'list-' + id">我的Id是js动态生成的</li>

示例1:字符截取

<!-- 在html中加入元素,定义表达式 -->
<p>{{str.substring(5,9)}}</p>
data() {return {str: '大家都叫我king'}
}

示例二:很简单就不一一演示了

<p>数字:{{number+1}}</p>
<p>{{ok ? 'yes' : 'no'}}</p>
<span :id="'users_id_'+id">小威</span>
new Vue({el: "#xw",data() {return {number: 99,ok: false,id: 66}}})

1.2 指令

1.2.1 核心指令

 v-if|v-else|v-else-if :根据其后表达式的bool值进行判断是否渲染该元素

 v-show:与v-if类似,只是会渲染其身后表达式为false的元素,而且会给这样的元素添加css代码:style="display:none"

 v-for:类似JS的遍历

 v-bind:在上面已用到,添加属性或元素

 v-on:v-on:(也可以用@替代),在上篇已讲述过,用来调用函数。

 v-model:用来自动更新绑定的元素的值  

示例1:

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>核心指令</title><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw">分数:<input v-model="score" /><div v-if="score>80">优秀</div><div v-else-if="score>60">良好</div><div v-else="score<60">还需努力</div></div></body><script type="text/javascript">new Vue({el: '#xw',data() {return {score: 60}}})</script></html>

示例二:

<div v-show="score==90">v-show-上优秀学员名单</div>

示例3:

结合v-model实现下拉框和复选框

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>核心指令</title><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw"><p>v-for</p><select v-model="hobbySelected"><option v-for="h in hobby" :value="h.id">{{h.name}}</option></select><div v-for="h in hobby"><input :value="h.id" type="checkbox" />{{h.name}}</div></div></body><script type="text/javascript">new Vue({el: '#xw',data() {return {hobby: [{id: "1",name: "beautifulgirl"},{id: "2",name: "按摩"},{id: "3",name: "洗jio"}],hobbySelected: 3};}})</script></html>

示例4:

<!--参数:href-->
<div><a v-bind:href="url">baidu</a>
</div><!--
参数:动态参数.
attname需要在data中定义,
注意:attname要全部小写!!
-->
<div><a v-bind:[attrname]="url">baidu</a><button v-on:[evname]="clickme">点我看看</button>
</div>

1.2.3 动态参数

注意:在动态参数中,作为参数的变量名(如:attrname)要全部小写,否则无效 !!

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>动态参数</title><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw"><p>动态参数</p><input v-model="evname" /><button v-on:[evname]="handle">动态参数</button></div></body><script type="text/javascript">new Vue({el: '#xw',data() {return {evname:'dblclick'}methods: {handle() {alert("触发事件");}}})</script>
</html>

Vue为v-bind和v-on这两个最常用的指令,提供了特定简写

指令简写示例
v-bind:xxx:xxxv-bind:href 简写为 :href
v-on:xxx@xxxv-on:click 简写为 @click

二、过滤器

        vue允许自定义过滤器,一般用于常见的文本格式化,过滤器可用的两个地方:双花括号插值v-bind表达式,过滤器应该被添加在js表达式的尾部,使用管道运算符 " | "

2.1 局部过滤器

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>过滤器</title><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw">{{msg}}<br />{{msg|single}}<br />{{msg|param(2,3)}}</div><script type="text/javascript">// 绑定边界	ES6具体体现new Vue({el: '#xw',data() {return {msg: "bug快离开~bug快离开~"};},filters: {'single': function(val) {return val.substring(2, 3);},'param': function(val, start, end) {return val.substring(start, end);}}})</script></body>
</html>

注1:过滤器函数接受表达式的值作为第一个参数 
注2:过滤器可以串联     
        {{ message | filterA | filterB }}
注3:过滤器是JavaScript函数,因此可以接受参数: 
        {{ message | filterA('arg1', arg2) }} 

2.2 全局过滤器

时间转换案例: 

//给Date类添加了一个新的实例方法format
Date.prototype.format = function (fmt) {//debugger;var o = {"M+": this.getMonth() + 1,                 //月份"d+": this.getDate(),                    //日"h+": this.getHours(),                   //小时"m+": this.getMinutes(),                 //分"s+": this.getSeconds(),                 //秒"q+": Math.floor((this.getMonth() + 3) / 3), //季度"S": this.getMilliseconds()             //毫秒};if (/(y+)/.test(fmt))fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));for (var k in o)if (new RegExp("(" + k + ")").test(fmt))fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));return fmt;
};function fmtDate(date, pattern) {var ts = date.getTime();var d = new Date(ts).format("yyyy-MM-dd hh:mm:ss");if (pattern) {d = new Date(ts).format(pattern);}return d.toLocaleString();
};

拷入date.js(日期格式化)放入项目js目录中,在页面中引入。
定义全局过滤器 

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>过滤器</title><script src="js/date.js"></script><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw"><p>{{date | fmtDate}}</p>无过滤器:<br />{{date}}</div><script type="text/javascript">// 全局过滤器Vue.filter('fmtDate', function(value) {return fmtDate(value, 'yyyy年MM月dd日')});// 绑定边界	ES6具体体现new Vue({el: '#xw',data() {return {date: new Date()};}})</script></body>
</html>

三、计算属性

   计算属性可用于快速计算视图(View)中显示的属性。这些计算将被缓存,并且只在需要时更新。

使用场景:当一个属性需要复杂的逻辑运算之后才能获取其值,可以使用计算属性,在一个计算属性中可以完成各种复杂的逻辑,包括运算,方法调用等,只要最终返回一个结果就可以了


语法:computed:{}

购物车案例:

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>计算属性</title><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw"><p>计算属性</p><table border="1" style="width: 600px;height: 300px;"><tr><td>物品</td><td>单价</td><td>数量</td><td>小计</td></tr><tr><td>帽子</td><td>{{maoziDanjia}}</td><td><input v-model="maozi" /></td><td>{{maoziTotal}}</td></tr><tr><td>衣服</td><td>{{yifuDanjia}}</td><td><input v-model="yifu" /></td><td>{{yifuTotal}}</td></tr><tr><td>裤子</td><td>{{kuziDanjia}}</td><td><input v-model="kuzi" /></td><td>{{kuziTotal}}</td></tr><tr><td>总价</td><td colspan="3">{{total}}</td></tr></table></div></body><script type="text/javascript">// 绑定边界	ES6具体体现new Vue({el: '#xw',data() {//定义所需属性值return {maoziDanjia: 10,yifuDanjia: 30,kuziDanjia: 20,maozi: 1,yifu: 1,kuzi: 1,km: 2,m: 2000};},computed: {maoziTotal() {return this.maoziDanjia * this.maozi;},yifuTotal() {return this.yifuDanjia * this.yifu;},kuziTotal() {return this.kuziDanjia * this.kuzi;},total() {return this.maoziTotal + this.yifuTotal + this.kuziTotal;}}})</script>
</html>

四、监听器

监听属性 watch,我们可以通过 watch 来响应数据的变化
   

语法:watch:{}

示例: 米和厘米的单位换算

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>计算属性</title><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw"><p>监听属性</p>米:<input v-model="m" />厘米:<input v-model="cm" /></div></body><script type="text/javascript">// 绑定边界	ES6具体体现new Vue({el: '#xw',data() {return {m: 2,cm: 200};},watch: {// v指的是m变量m: function(v) {this.cm = parseInt(v) * 100;},// v指的是km变量cm: function(v) {this.m = parseInt(v) / 100;}}})</script>
</html>

五、排座案例

<!DOCTYPE html>
<html><head><title>排座</title><script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script></head><body><div id="app"><h2>排座</h2><input type="text" v-model="seatInput1"><input type="text" v-model="seatInput2"><input type="text" v-model="seatInput3"><hr><h3>用户:</h3><ul><!-- 遍历过滤器传来的值 --><li v-for="user in filteredUsers" :key="user.id">{{ user.name }}</li></ul><hr></div><script>new Vue({el: '#app',data: {seatInput1: '',seatInput2: '',seatInput3: '',users: [{id: 1,name: '老王'},{id: 2,name: '老六'},{id: 3,name: '老八'},{id: 4,name: '老聂'},{id: 5,name: '老五'}]},/* 定义一个filteredUsers计算属性 */computed: {/* 使用filter方法来过滤users数组中的元素。filter方法接受一个回调函数作为参数,该回调函数会对数组中的每个元素进行判断,并返回一个新的数组,其中包含满足条件的元素。 */filteredUsers() {return this.users.filter(/* 使用=>箭头函数的语法来定义一个匿名函数。这个匿名函数接受一个参数user,表示users数组中的每个元素。 */user => {/* 使用逻辑运算符&&来判断user.name是否不等于seatInput1、seatInput2和seatInput3的值。如果满足这个条件,说明user.name不等于任何一个输入框的值,那么这个元素就会被保留在过滤后的数组中。 */return user.name !== this.seatInput1 &&user.name !== this.seatInput2 &&user.name !== this.seatInput3});}}});</script></body>
</html>

小结:计算属性和监听属性的区别

计算属性:是一种依赖于其他属性计算得出的属性。它的值是根据其依赖的属性动态计算而来的,并且会进行缓存,只有在依赖的属性发生变化时才会重新计算。计算属性适用于需要根据其他属性进行复杂计算或处理的场景。通过使用计算属性,可以将复杂的逻辑封装起来,使代码更加清晰和可维护。

监听属性:是一种用于监听指定属性变化并执行相应操作的属性。当监听的属性发生变化时,可以执行指定的回调函数来响应变化。监听属性适用于需要在属性变化时执行异步或开销较大的操作的场景。通过使用监听属性,可以实时监测属性的变化并执行相应的操作,例如发送网络请求或执行复杂的计算。

        计算属性适用于根据其他属性进行计算得出结果的场景,而监听属性适用于需要实时监测属性变化并执行相应操作的场景。两者的区别在于计算属性是根据其他属性进行计算得出结果,而监听属性是在属性变化时执行相应操作。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

无涯教程-JavaScript - RAND函数

描述 RAND函数返回大于或等于0且小于1的均匀分布的随机实数。每次计算工作表时,都会返回一个新的随机实数。 语法 RAND ()争论 RAND函数没有参数。 Notes 您可以在a和b之间生成一个随机实数,其中 RAND ()*(b-a)a 如果要使用RAND生成随机数,但又不想每次计算单元格时都更改…

Android.bp常用语法和预定义属性

介绍 Android.bp是Android构建系统中用于定义模块和构建规则的配置文件&#xff0c;它使用一种简单的声明式语法。以下是Android.bp的一些常见语法规则和约定&#xff1a; 注释&#xff1a; 单行注释使用//符号。 多行注释使用/和/包围。 和go语言相同 // 这是单行注释 /* 这是…

开源分布式存储系统(HDFS、Ceph)架构分析

文章目录 中间控制节点架构-HDFSNameNode节点分析DataNode节点分析SecondNameNode节点分析Client分析 完全无中心架构-CephCeph Monitor分析Ceph OSD分析Ceph Manager分析Ceph Clients分析 小结HDFS优点缺点 Ceph优点缺点 参考 中间控制节点架构-HDFS 以HDFS&#xff08; Hado…

无涯教程-JavaScript - RADIANS函数

描述 RADIANS函数将度数转换为弧度。度和弧度之间的转换是通过以下关系式计算的 180度π弧度 其中π是数学常数,PI3.14159265358979 ... 语法 RADIANS (angle)争论 Argument描述Required/OptionalAngleAn angle in degrees that you want to convert.Required 适用性 E…

Linux 信号相关

int kill(pid_t pid, int sig); -功能&#xff1a;给某个进程pid 发送某个信号 参数sig可以使用宏值或者和它对应的编号 参数pid&#xff1a; >0 &#xff1b;将信号发给指定的进程 0&#xff1b;将信号发送给当前的进程组 -1&#xff1b;发送给每一个有权限接受这个信号的…

C数据结构二.练习题

一.求级数和 2.求最大子序列问题:设给定一个整数序列 ai.az..,a,(可能有负数).设计一个穷举算法,求a 的最大值。例如,对于序列 A {1,-1,1,-1,-1,1,1,1,1.1,-1,-1.1,-1,1,-1},子序列 A[5..9](1,1,1,1,1)具有最大值5 3.设有两个正整数 m 和n,编写一个算法 gcd(m,n),求它们的最大公…

Linux static_key原理与应用

文章目录 背景1. static-key的使用方法1.1. static-key定义1.2 初始化1.3 条件判断1.4 修改判断条件 2、示例代码参考链接 背景 内核中有很多判断条件在正常情况下的结果都是固定的&#xff0c;除非极其罕见的场景才会改变&#xff0c;通常单个的这种判断的代价很低可以忽略&a…

ipad录屏在哪?学会这些方法,轻松找到录屏功能

随着科技的不断发展&#xff0c;ipad已经成为人们日常生活中不可或缺的工具之一&#xff0c;它不仅能够帮助我们处理各种任务&#xff0c;还可以用来记录和分享有趣的瞬间。在本篇文章中&#xff0c;我们将详细介绍ipad录屏在哪里&#xff0c;为您提供更多录制和编辑视频的可能…

【LeetCode热题100】--15.三数之和

15.三数之和 注意&#xff1a;最后答案中不能包含重复的三元组 使用排序双指针 可以使用三重循环枚举三元组&#xff0c;但是需要哈希表进行去重操作&#xff0c;得到不包含重复三元组的最终答案&#xff0c;消耗量大量的时间和空间 对于不重复的本质&#xff0c;保持三重循环…

sudo+vim+g++/gcc+makefile+进度条

目录 一、信任表中加入指定的普通用户&#xff08;使其能使用sudo&#xff09; 二、vim的使用 &#xff08;一&#xff09;基本概念 1. 正常/普通/命令模式(Normal mode) 2. 插入模式(Insert mode) 3. 末行模式(last line mode) &#xff08;二&#xff09;vim正常模式…

怎么防止360安全卫士修改默认浏览器?

默认的浏览器 原先选项是360极速浏览器&#xff08;如果有安装的话&#xff09;&#xff0c;我这里改成了Chrome。 先解锁 才能修改。

[SQL Server]在应使用条件的上下文(在 ‘)‘ 附近)中指定了非布尔类型的表达式,查询时间大于某个数值时

这种条件查询条件里面不要有空格&#xff0c;一个也不要有 这种条件查询条件里面不要有空格&#xff0c;一个也不要有 $giftsDb::table(drawgot)->where(disabtime,<,"2030-01-03")->select();