当前位置: 首页 > news >正文

Vue的v-for指令、事件处理、表单控制

一 条件渲染

指令释义
v-if相当于: if
v-else相当于:else
v-else-if相当于:else if
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>if、else if、else</title><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script>
</head>
<body>
<div id="box"><h3>案例:if、else if、else</h3><h2 v-if="type==='1'">A</h2><h2 v-else-if="type==='2'">B</h2><h2 v-else>C</h2>
</div>
</body>
<script>let vm = new Vue({el: '#box',data: {type: '1',}})
</script>
</html>

二 列表渲染

1. v-if+v-for+v-else控制购物车商品的显示

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>v-if + v-for + v-else控制购物车商品的显示</title><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script><style>table, td {border: 1px solid black;text-align: center;}</style>
</head>
<body>
<div id="box"><h2>我的购物车</h2><button @click="show">刷新购物车</button><br><br><table v-if="!shopping_car.length==0"><tr><td>商品名称</td><td>价格</td></tr><tr v-for="item in shopping_car"><td>{{item.name}}</td><td>{{item.price}}</td></tr></table><table v-else><tr><td>商品名称</td><td>价格</td></tr><tr><td>暂无信息</td><td>暂无信息</td></tr></table>
</div>
</body>
<script>let vm = new Vue({el: '#box',data: {isActive: false,shopping_car: []},methods: {show() {this.shopping_car = [{name: 'Threadripper 3990X', price: '29999元'},{name: 'NVIDIA RTX 8000', price: '59999元'},{name: 'ROG ZENITH II EXTREME', price: '9999元'},]}}})
</script>
</html>

2. v-for遍历数组(列表)、对象(字典)、数字

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>v-for遍历数组(列表)、对象(字典)</title><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script><style>table, td {border: 1px solid black;text-align: center;}</style>
</head>
<body><div id="box"><h2>数组(列表)for循环遍历</h2><ul><li v-for="(value,index) in list_test">{{index}} —— {{value}}</li></ul><h2>对象(字典)for循环遍历</h2><ul><li v-for="(value,key) in dic_test">{{key}} —— {{value}}</li></ul><h2>数组(列表)套对象(字典)for循环遍历</h2><table><tr><td>姓名</td><td>年龄</td><td>性别</td><td>国籍</td></tr><tr v-for="info in summary_test"><td>{{info.name}}</td><td>{{info.age}}</td><td>{{info.gender}}</td><td>{{info.country}}</td></tr></table>
</div>
</body>
<script>let vm = new Vue({el: '#box',data: {list_test: ['First', 'second', 'Third', 'Forth', 'Fifth'],dic_test:{name: 'Darker', age: 18, gender: 'male'},summary_test: [{name: 'Alan', age: 23, gender: 'male', country: 'America'},{name: 'Ben', age: 15, gender: 'male', country: 'Australia'},{name: 'Cindy', age: 12, gender: 'female', country: 'Japan'},{name: 'Darker', age: 18, gender: 'male', country: 'China'},{name: 'Elisa', age: 26, gender: 'female', country: 'Mexico'},]}})
</script>
</html>

注意!Vue中:

  • 数组indexvalue反的
  • 对象keyvalue也是反的

3. key值 的解释

vue中使用的是虚拟DOM,会和原生的DOM进行比较,然后进行数据的更新,提高数据的刷新速度(虚拟DOM用了diff算法)

  • v-for循环数组、对象时,建议在控件/组件/标签写1个key属性,属性值唯一
  • 页面更新之后,会加速DOM的替换(渲染)
  • :key="变量"

4. 数组更新与检测

可以检测到变动的数组操作:
  • push:最后位置添加
  • pop:最后位置删除
  • shift:第一个位置删除
  • unshift:第一个位置添加
  • splice:切片
  • sort:排序
  • reverse:反转
检测不到变动的数组操作:
  • filter():过滤
  • concat():追加另一个数组
  • slice():
  • map():
原因:

作者重写了相关方法(只重写了一部分方法,但是还有另一部分没有重写)

解决方法:
// 方法1:通过 索引值 更新数组(数据会更新,但是页面不会发生改变)
vm.arrayList[0]
"Alan"
vm.arrayList[0]='Darker'
"Darker"// 方法2:通过 Vue.set(对象, index/key, value) 更新数组(数据会更新,页面也会发生改变)
Vue.set(vm.arrayList, 0, 'Darker')

三 事件处理

事件释义
input当输入框进行输入的时候 触发的事件
change当元素的值发生改变时 触发的事件
blur当输入框失去焦点的时候 触发的事件

change 和 blur 最本质的区别:

  • 如果输入框为空,失去焦点后,change不会触发,但是blur会触发

1.过滤案例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>过滤案例</title><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script>
</head>
<body>
<div id="box"><p><input type="text" v-model="myText" @input="handleInput" placeholder="请输入要筛选的内容:"></p>
<!-- <p><input type="text" v-model="myText" @change="handleInput" placeholder="请输入要筛选的内容:"></p> -->
<!-- <p><input type="text" v-model="myText" @blur="handleInput" placeholder="请输入要筛选的内容:"></p> --><ul><li v-for="data in newList">{{data}}</li></ul>
</div>
</body>
<script>var vm = new Vue({el: '#box',data: {myText: '',dataList: ['a', 'at', 'atom', 'be', 'beyond', 'cs', 'csrf'],newList: ['a', 'at', 'atom', 'be', 'beyond', 'cs', 'csrf'],},methods: {handleInput() {this.newList = this.dataList.filter(item => {// item.indexOf(this.myText):输入框中输入的字符串在筛选元素中的索引return item.indexOf(this.myText) > -1   // 返回索引大于1的元素:>-1 就表示包含在其中})},},})
</script>
</html>

2.事件修饰符

事件修饰符释义
.stop只处理自己的事件,父控件冒泡的事件不处理(阻止事件冒泡)
.self只处理自己的事件,子控件冒泡的事件不处理
.prevent阻止a链接的跳转
.once事件只会触发一次(适用于抽奖页面)

使用修饰符时,顺序很重要;相应的代码会以同样的顺序产生

  • 用 v-on:click.prevent.self 会阻止所有的点击
  • 而 v-on:click.self.prevent 只会阻止对元素自身的点击
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>事件修饰符</title><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script>
</head>
<body>
<div id="box">
<!--    <ul @click="handleUl">--><ul @click.self="handleUl">
<!--        <li v-for="data in dataList" @click="handleLi">{{data}}</li>--><li v-for="data in dataList" @click.stop="handleLi">{{data}}</li><li><a href="http://www.baidu.com">不拦截</a></li><li><a href="http://www.baidu.com" @click="handleLink($event)">点击拦截</a></li><li><a href="https://www.baidu.com" @click.prevent="handleLink">点击拦截</a></li><li><button @click.once="test">只执行一次</button></li></ul>
</div>
</body>
<script>var vm = new Vue({el: '#box',data: {dataList: ['1','22','333','4444']},methods: {handleUl(ev){console.log('ul被点击了')},handleLi(){console.log('li被点击了')ev.stopPropagation()    // 点击事件停止 冒泡(向父组件传递时间)},handleLink(ev){ev.preventDefault()},test(){alert('只触发1次')}}})
</script>
</html>

3.按键修饰符

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>按键修饰符</title><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script>
</head>
<body>
<div id="box"><!--    <input type="text" v-model="myInput" @keyup="handleKey">--><!--    <input type="text" v-model="myInput" @keyup.13="handleKey">--><input type="text" @keyup="handleKey1"><input type="text" @keyup.enter="handleKey2">
</div>
</body>
<script>var vm = new Vue({el: '#box',data: {dataList: ['1', '22', '333', '4444']},methods: {handleKey1(ev) {console.log('按下了' + ev)// if (ev.keyCode==13){//     console.log('回车键被按下了')// }},handleKey2(ev) {console.log('按下了回车键')}}})
</script>
</html>

四:数据双向绑定

v-model的使用

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script>
</head>
<body>
<div id="box"><input type="text" v-model="myText" placeholder="请输入内容">您输入的内容是:{{myText}}
</div>
</body>
<script>var vm = new Vue({el: '#box',data: {myText: '',},})
</script>
</html>

五:表单控制

1.checkbox选中

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>checkbox</title><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script>
</head>
<body>
<div id="box"><input type="text" placeholder="请输入用户名:"><br><input type="password" placeholder="请输入密码:"><br><input type="checkbox" v-model="radio">记住用户名
</div>
</body>
<script>var vm = new Vue({el: '#box',data: {myText: '',textBig: '',radio: false,},})
</script>
</html>

2.单选

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>单选</title><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script>
</head>
<body>
<div id="box"><input type="radio" v-model="radio" value="男"><input type="radio" v-model="radio" value="女"><input type="radio" v-model="radio" value="保密">保密<br><br>您选择的性别:{{radio}}
</div>
</body>
<script>var vm = new Vue({el: '#box',data: {radio: '',},})
</script>
</html>

3.多选

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>多选</title><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script>
</head>
<body>
<div id="box"><input type="checkbox" v-model="many" value="篮球">篮球<input type="checkbox" v-model="many" value="足球">足球<input type="checkbox" v-model="many" value="棒球">棒球<input type="checkbox" v-model="many" value="桌球">桌球<br><br>您喜欢的球类:{{many}}
</div>
</body>
<script>var vm = new Vue({el: '#box',data: {many: [],},})
</script>
</html>

相关文章:

  • 前端页面优化做的工作
  • 如何确定网络的深度和每层的节点(神经元)数目?
  • Unity3d 实现直播功能(无需sdk接入)
  • GPT实战系列-简单聊聊LangChain
  • 【适用于Jetson Orin Nano的录屏软件】
  • 构建基于RHEL9系列(CentOS9,AlmaLinux9,RockyLinux9等)的MySQL8.0.32的RPM包
  • vue3+vite+ts+pinia新建项目(略详细版)
  • 使用MistNet在COCO128数据集上协作训练Yolo-v5
  • JS加密/解密之js加密小工具
  • win10在启动游戏时报错,提示“d3dx9_25.dll文件丢失”,怎么办?d3dx9_25.dll丢失如何自动修复
  • SCI一区级 | Matlab实现RIME-CNN-LSTM-Mutilhead-Attention多变量多步时序预测
  • 发起人自选-钉钉审批
  • Elasticsearch 地理空间搜索 - 远超 OpenSearch
  • 上海亚商投顾:创业板指放量涨近2% 全市场超4400只个股上涨
  • Vue入门五(Vue-CLI项目搭建|vue项目目录介绍|vue项目开发规范|es6导入导出语法)
  • JavaScript 如何正确处理 Unicode 编码问题!
  • Android路由框架AnnoRouter:使用Java接口来定义路由跳转
  • CSS3 聊天气泡框以及 inherit、currentColor 关键字
  • JavaScript创建对象的四种方式
  • Java新版本的开发已正式进入轨道,版本号18.3
  • PAT A1050
  • React Native移动开发实战-3-实现页面间的数据传递
  • Spring思维导图,让Spring不再难懂(mvc篇)
  • Vue组件定义
  • 不上全站https的网站你们就等着被恶心死吧
  • 大数据与云计算学习:数据分析(二)
  • 前端
  • 如何学习JavaEE,项目又该如何做?
  • 使用Tinker来调试Laravel应用程序的数据以及使用Tinker一些总结
  • 网页视频流m3u8/ts视频下载
  • 要让cordova项目适配iphoneX + ios11.4,总共要几步?三步
  • 好程序员大数据教程Hadoop全分布安装(非HA)
  • ​​​​​​​​​​​​​​Γ函数
  • #HarmonyOS:软件安装window和mac预览Hello World
  • #include<初见C语言之指针(5)>
  • #控制台大学课堂点名问题_课堂随机点名
  • (12)Linux 常见的三种进程状态
  • (4) openssl rsa/pkey(查看私钥、从私钥中提取公钥、查看公钥)
  • (4)STL算法之比较
  • (八)Flask之app.route装饰器函数的参数
  • (二)丶RabbitMQ的六大核心
  • (六)Hibernate的二级缓存
  • (十八)SpringBoot之发送QQ邮件
  • (十八)三元表达式和列表解析
  • (转)GCC在C语言中内嵌汇编 asm __volatile__
  • (转)创业家杂志:UCWEB天使第一步
  • (转)全文检索技术学习(三)——Lucene支持中文分词
  • (轉貼) VS2005 快捷键 (初級) (.NET) (Visual Studio)
  • .NET 5种线程安全集合
  • .NET Core 项目指定SDK版本
  • .net core开源商城系统源码,支持可视化布局小程序
  • .NET3.5下用Lambda简化跨线程访问窗体控件,避免繁复的delegate,Invoke(转)
  • .NET多线程执行函数
  • .Net开发笔记(二十)创建一个需要授权的第三方组件
  • .net中我喜欢的两种验证码