vue数据双向绑定

2023-05-16

5.Vue数据双向绑定

5.1.什么是双向数据绑定

Vue.js 是一个 MVVM 框架,即数据双向绑定,即当数据发生变化的时候,视图也就发生变化,当视图发生变化的时候,数据也会跟着同步变化。这也算是 Vue.js 的精髓之处了。

值得注意的是,我们所说的数据双向绑定,一定是对于 UI 控件来说的,非 UI 控件不会涉及到数据双向绑定。单向数据绑定是使用状态管理工具的前提。如果我们使用 vuex,那么数据流也是单项的,这时就会和双向数据绑定有冲突。

5.2 怎么实现双向数据绑定

v-model
v-model 指令可以在表单及元素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。它负责监听用户的输入事件以更新数据,并对一些极端场景进行一些特殊处理。

注意:v-model 会忽略所有表单元素的 value、checked、selected 特性的初始值而总是将 Vue 实例的数据作为数据来源。你应该通过 JavaScript 在组件的 data 选项中声明初始值!

测试案例:

用非v-model方式的时候,是不能双向绑定的

		
	<div id="app">     
        <input type="text"  :value="msg"  />
        <div>{{msg}}</div>
    </div>
    
	 <script>
	     var app = new Vue({
	         el:'#app',
	         data:{
	            msg:"hello"
	         }
	     });
	 </script>

在这里插入图片描述

改为v-model方式绑定:

<div id="app">     
        <input type="text"  v-model="msg"  />
        <div>{{msg}}</div>
    </div>
    
	 <script>
	     var app = new Vue({
	         el:'#app',
	         data:{
	            msg:"hello"
	         }
	     });
	 </script>

在这里插入图片描述

案例2:

   <div id="app">
        <select v-model="selected">
            <option value="">--请选择--</option>
            <option value="北京">北京</option>
            <option value="上海">上海</option>
            <option value="武汉">武汉</option>
        </select>
        <p>{{selected}}</p>
    </div>
     <script>
         var v= new Vue({
             el:"#app",
             data:{selected:'' }
         });
     </script>

在这里插入图片描述

案例3:

   <div id="app">
        <input type="checkbox" id="jack" value="吃饭" v-model="checkedValues">
        <label for="jack">吃饭</label>
        <input type="checkbox" id="john" value="睡觉" v-model="checkedValues">
        <label for="john">睡觉</label>
        <input type="checkbox" id="mike" value="打豆豆" v-model="checkedValues">
        <label for="mike">打豆豆</label>

        <div>选中的值: </div>
        <ul>
          <li v-for="item in checkedValues" >{{item}}</li>
        </ul>    
    </div>
    
    <script type="text/javascript">
    var v = new Vue({
        el: '#app',
        data: {
            checkedValues:[]
        }
    });
    </script>

在这里插入图片描述

6.Vue事件绑定

v-on
  v-on:事件名 = “方法名”
  简写方式: @事件名 = “方法名”
  事件名有哪些: click|keydown|keyup|mouseover|mouseout|自定义事件名

测试案例1:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<script type="text/javascript" src="js/vue.js" ></script>
	</head>
	<body>
		
		<div id="app">
			
			<input type="button" value="-"  v-on:click="sub" />
			<input type="text" v-model="num" />
			<input type="button" value="+" @click="plus" />
			
			
		</div>
		
		<script>
			
			var v=new Vue({
				
				el:"#app",
				data:{
					num:1
				},
				methods:{
					sub:function(){
						if(this.num>0)
						  this.num-=1;
					},
					plus:function(){
						this.num=parseInt(this.num)+1; 
					}
				}
				
			})
			
		</script>
		
	</body>
</html>

在这里插入图片描述

在这里插入图片描述

v-on: 可以简化为@

<div id="app">
	<input type="button" value="-" @click="sub" />
	<input type="text"  v-model="count" />
	<input type="button" value="+" @click="plus" />
</div>

测试案例2:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<script type="text/javascript" src="js/vue.js" ></script>
	</head>
	<body>
		
		输入分数,按回车,显示等级
		
		<div id="app">
			
			<div>等级:{{level}}</div>
			
			<input type="text"  v-on:keyup.enter="show" v-model="score" />
			
		</div>
		
		
		 <script type="text/javascript">
	        var app = new Vue({
	            el: '#app',
	            data: {
	                level: '',
	                score:''
	            },
	            methods: {
	               
	                show: function () {
	                  if(this.score>=0 && this.score<60)
	                      this.level="D";
	                  else if(this.score<80)
	                      this.level="C";   
	                  else if(this.score<90)
	                      this.level="B";
	                  else
	                      this.level="A";
	                }
	            }
	
	        })
        </script>
		
		
	</body>
</html>

测试结果:

在这里插入图片描述

7.综合案例

根据前面学习的vue的基础语法和事件绑定,实现一下商品的查询,添加,删除功能。

测试案例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
    <script type="text/javascript" src="js/vue.js"></script>
</head>
<body>
    <div id="app">
        <div style="text-align: center;" >
            <div >
                <h3 >商品操作页面</h3>
            </div>
		 <div  style="text-align:center">
		                 序号:<input type="text"  v-model="id"/>
		                 名称:<input type="text"  v-model="name"/>
		                 价格:<input type="text"  v-model="price"/>
		      <input type="button" value="添加" @click="add()"/><br/>
		                   搜索:<input type="text" v-model="searchKey"/>
                
            </div>
        </div>
        <table style="width: 800px; margin-left: auto; margin-right: auto;" border="1">
            <header>
                <tr>
                    <td>序号</td>
                    <td>名称</td>
                    <td>价格</td>
                    <td>操作</td>
                </tr>
            </header>
        <tbody>
            <tr v-for="item in search(searchKey)" :key="item.id">
                <td>{{ item.id }}</td>
                <td>{{ item.name }}</td>
                <td>{{ item.price }}</td>
                <!-- .prevent阻止事件的默认行为,这里是阻止超链接默认的跳转功能-->
                <td><a href="" @click.prevent="del(item.id)">删除</a></td>
            </tr>
        </tbody>
      </table>
    </div>

    <script type="text/javascript">
        var vm = new Vue({
            el : "#app",
            data:{
                id:'',
                name:'',
                searchKey:'',
                list:[
                    {id:1,name:'T恤',price:100},
                    {id:2,name:'西装',price:500},
                    {id:3,name:'连衣裙',price:200},
                    {id:4,name:'衬衫',price:150}
                ]
            },
            methods:{
                add(){
                	//将表单中的数据组装为一个商品对象
                    var good = {
                            id:this.id,
                            name:this.name,
                            price:this.price
                        };
                    //存入list中
                    this.list.push(good);
                    //将表单数据清空
                    this.id = this.name = this.price='';
                },
                del(id){
                	//遍历查询
                    var index = this.list.findIndex( item => {
                        if(id == item.id){
                            return true;
                        }
                    });
                    this.list.splice(index,1);//JavaScript中的splice(index,i)方法:从已知数组的index下标开始,删除i个元素
                },
                search(searchKey){
                	//filter() 方法创建一个新的数组,新数组中的元素是数组中符合条件的所有元素组合而成
                    return this.list.filter(item => {
                        if(item.name.includes(searchKey)){
                            return item;
                        }
                    });
                }
            }
        })
    </script>
</body>
</html>

测试结果:

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

8.Template 标签

template的作用是模板占位符,可帮助我们包裹元素,但在循环过程当中,template不会被渲染到页面上

比如:

<div v-for="value in user">{{value}}</div>

这个循环是做在div上面的,如果需要循环的内容很多,比如span标签也要做这个循环

<div v-for="value in user">{{value}}</div>
<span v-for="value in user">{{value}}</span>

则需要把循环提出来,但这样会多一个div标签

<div v-for="value in user">
    <div>{{value}}</div>
    <span>{{value}}</span>
</div>

如果不想多一个标签,可以用template,template不会渲染到页面上

<template v-for="value in user">
    <div>{{value}}</div>
    <span>{{value}}</span>
</template>

另外,template可以用到制作模板。

方法1:直接在vue对象中定义

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<script type="text/javascript" src="js/vue.js" ></script>
	</head>
	<body>
   <!--这里会显示template里的内容-->
	<div id="app">
	   
	</div>
	
	<script>
	    var  v = new Vue({
	        el:"#app",
	        data:{
	            msg:"daimenglaoshi"
	        },
	        template:"<div>{{msg}}</div>"//模板中只能有一个根元素
	    });
	</script>
	</body>
</html>

方法2:写在template标签里

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<script type="text/javascript" src="js/vue.js" ></script>
	</head>
	<body>
		
		
	<!--这里会显示template标签里的内容-->
	<div id="app"></div>
	
	<!--此处template标签必须在vue绑定的元素外面定义,并且在页面中不显示下面的template标签中的内容-->
	<template id="temp">
	    <div>{{msg}}<div>	  
	</template>
	
	<script>
	    let vm = new Vue({
	        el:"#app",
	        data:{
	            msg:"daimenglaoshi"
	        },
	        //通过该属性可以将自定义的template属性中的内容全部替换app的内容,并且会覆盖里面原有的内容,并且在查看dom结构时没有template标签
	        template:"#temp"
	      
	    });
	</script>		
	</body>
</html>

方法3:写在script标签里

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<script type="text/javascript" src="js/vue.js" ></script>
	</head>
	<body>

	<div id="app"></div>
	
	<script type="x-template" id="temp">
       <div>{{msg}}</div>
   </script>
	
	<script>
	    var  v = new Vue({
	        el:"#app",
	        data:{
	            msg:"daimenglaoshi"
	        },
	        template:"#temp"//模板中只能有一个根元素
	    });
	</script>
	</body>
</html>

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

vue数据双向绑定 的相关文章

  • 做程序员老婆的幸福

    刚好看网上一个写程序员老公的 说说程序员老公的一些事情 请帮忙分析是不是典型程序员 xff0c 想起自己就是一个程序员 xff0c 也是一个老公 xff0c 却不以为然起来 虽然不以为然 xff0c 却并没有驳斥的任何意思 毕竟很多人都不一
  • 好习惯成就好程序员

    公司搞了一次技术峰会 xff0c 我有机会和大家聊了一下有关如何成功的问题 会上我向大家提出了我的想法 xff0c 好习惯才能成就好程序员 有很多人可能对这句话很不以为然 xff0c 我也不忙辩解 xff0c 先回答我下面的一个问题 现在我
  • 程序江湖:第三章 莫等闲白了少年头

    周五因为羽毛球比赛 xff0c 没有更新 xff0c 今天继续 读者反馈 xff1a 很多读者反馈主人公的名字比较土 呵呵这个没关系 xff0c 可以在整理的时候统一修改 另外有些人表示特别希望看到职场的故事 xff0c 这个放心 本就是这
  • 程序江湖:第二十章 讲标的前一晚上

    说明 xff1a 非常抱歉 xff0c 这周参加了太多的会议 原来写作也是需要心情的 xff0c 当没有心情的时候 xff0c 你都懒得动笔 欧阳明来到云南的最主要的目的 xff0c 是为了应对昆明客户要求的评标 就是客户邀请了几家资质还可
  • springboot项目搭建

    一 Springboot 基本概念 1 1 什么是 springboot Spring Boot是由Pivotal团队提供的全新框架 xff0c 其设计目的是用来简化新Spring应用的初始搭建以及开发过程 该框架使用了特定的方式来进行配置
  • 管理 VS. 面向对象设计

    我是在吃虾的时候 xff0c 突然想起这个关联的 管理 xff0c 往往就是给你一堆事 xff0c 然后再给你一些人 xff0c OK xff0c 你去做吧 这是你的使命 下面我们来做类比吧 首先一个问题 xff0c 你是认为人重要 xff
  • 技术管理案例:代码规范还要继续推行吗?

    这是实际工作中总结的一个典型案例 是真实的 写出来供大家参考 案例 xff1a 技术经理 Y 今年新到了一个产品部门 xff0c 发现原来产品的代码很乱 xff0c 遗留的问题很多 而现有的人员 xff0c 又大半是新招的 xff0c 很多
  • 苹果成功的根本:统筹创新

    这周的某天中午 xff0c 我们聊起了这个话题 xff0c 是关于苹果为什么成功的话题 很多人都说是因为苹果的创新能力很强 但是诺基亚也不缺乏创新啊 xff01 为什么苹果就能胜出呢 xff1f 我个人认为这有很多方面是因为乔布斯 xff0
  • 建立健康的职业发展观

    Google的Reader要下线了 xff0c 很多人都说这是因为Blog的没落 微博的兴起 xff0c 确实给了很多人表达情绪的方式 如果我能够用140个字 xff0c 清晰的表达我的观点 xff0c 并且能够让我的读者做到一点点认可 x
  • Android Gradle Plugins系列-01-自定义Gradle插件入门指南

    前言 本文内容已经有很多大佬写过了 xff0c 不过这里为了知识体系的完整 xff0c 就再写一遍 xff0c 并加入Maven Publish插件的使用 xff0c 不感兴趣跳过就好 官方文档 xff1a Developing Custo
  • Android Gradle Plugins系列-02-Maven Publish 插件踩坑指南

    前言 可能有读者会疑惑 xff0c Maven Publish 插件又是啥玩意 xff1f 确定不是Maven插件吗 xff1f 不要逗我 让笔者慢慢道来 xff0c 如果你刚好把AndroidStudio升级到Android Studio
  • Android Jetpack系列-实现Application作用域的共享ViewModel用于Activity和Fragment的相互通信

    目录 前言 搞清楚activityViewModels的本质 定义Application作用域的ViewMode ApplicationViewModelLazy BaseViewModelApplication 使用方法 自定义Appli
  • Android 音视频开发实践系列-04-Android WebRTC推流到SRS服务器实现直播功能

    目录 前言 了解WebRTC 部署SRS服务器 下载源码并运行 可能遇到的问题 create session create session add publisher publish negotiate no found valid H 2
  • 搭建Android日志系统 美团点评大前端Logan入门指南

    目录 前言 总览 快速开始 下载官方源码 使用IDEA打开Logan Server项目 使用Docker下载MySQL镜像并启动容器 运行Logan Server 修改db properties 修改log4j properties 配置M
  • Android代码重构系列-03-用了Kotlin就别再用Java的思维写代码了(持续更新)

    前言 还记得刚开始在正式项目上用Kotlin写代码时 xff0c 很多代码是直接复制Java过来转成Kotlin的 xff0c 结果代码Review的时候被评论成是用Java的思维写Kotlin代码 xff0c 完全没有利用到Kotlin的
  • springboot项结构分析

    三 SpringBoot 结构 3 1 SpringBoot 工作原理 Spring boot应用程序采用各种Starters启动器 入口类是包含 64 SpringBootApplication注解和main方法的类 然后使用 64 Co
  • Android 音视频开发实践系列-06-初步了解H.264视频编解码技术标准

    本文来自笔者本人的语雀博客 xff0c 由于语雀升级后不再满足笔者的需求 xff0c 因此之后笔者会陆续将一些之前已经发布但尚有价值的文章搬家到CSDN 1 前言 作为音视频行业从业者 xff0c 怎么能不理解H 264视频编解码技术标准
  • 记一次Git未Commit直接Pull导致本地代码丢失后的挽救过程

    第一次遇到这种问题 xff0c 有点紧张 好吧 xff0c 废话不多说 xff0c IDEA或者AndroidStudio进入Git Uncommiteed Changes gt Unstash Changes xff1a 在弹出的Unst
  • java异常处理(较详细)

    在使用计算机语言进行项目开发的过程中 xff0c 即使程序员把代码写得尽善尽美 xff0c 在系统的运行过程中仍然会遇到一些问题 xff0c 因为很多问题不是靠代码能够避免的 比如 xff1a 客户输入数据的格式 xff0c 读取文件是否存
  • 生产者,消费者

    生产者 xff0c 消费者 lock span class token comment 生产者消费者 lock span span class token keyword public span span class token keywo

随机推荐