您当前的位置:首页 > 网站建设 > javascript
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax | jQuery | 小程序 |

VUE的数据代理与事件详解

51自学网 2022-02-21 13:37:33
  javascript

回顾Object.defineProperty方法

<!DOCTYPE html><html>	<head>		<meta charset="UTF-8" />		<title>回顾Object.defineproperty方法</title>	</head>	<body>		<script type="text/javascript" >			let number = 18			let person = {				name:'张三',				sex:'男',			} 			Object.defineProperty(person,'age',{				// value:18,				// enumerable:true, //控制属性是否可以枚举,默认值是false				// writable:true, //控制属性是否可以被修改,默认值是false				// configurable:true //控制属性是否可以被删除,默认值是false 				//当有人读取person的age属性时,get函数(getter)就会被调用,且返回值就是age的值				get(){					console.log('有人读取age属性了')					return number				}, 				//当有人修改person的age属性时,set函数(setter)就会被调用,且会收到修改的具体值				set(value){					console.log('有人修改了age属性,且值是',value)					number = value				} 			}) 			// console.log(Object.keys(person)) 			console.log(person)		</script>	</body></html>

何为数据代理

数据代理:通过一个对象代理对另一个对象中属性的操作(读/写)

<!DOCTYPE html><html>	<head>		<meta charset="UTF-8" />		<title>何为数据代理</title>	</head>	<body>		<!-- 数据代理:通过一个对象代理对另一个对象中属性的操作(读/写)-->		<script type="text/javascript" >			let obj = {x:100}			let obj2 = {y:200} 			Object.defineProperty(obj2,'x',{				get(){					return obj.x				},				set(value){					obj.x = value				}			})		</script>	</body></html>

Vue中的数据代理

<!DOCTYPE html><html>	<head>		<meta charset="UTF-8" />		<title>Vue中的数据代理</title>		<!-- 引入Vue -->		<script type="text/javascript" src="../js/vue.js"></script>	</head>	<body>		<!-- 				1.Vue中的数据代理:							通过vm对象来代理data对象中属性的操作(读/写)				2.Vue中数据代理的好处:							更加方便的操作data中的数据				3.基本原理:							通过Object.defineProperty()把data对象中所有属性添加到vm上。							为每一个添加到vm上的属性,都指定一个getter/setter。							在getter/setter内部去操作(读/写)data中对应的属性。		 -->		<!-- 准备好一个容器-->		<div id="root">			<h2>学校名称:{{name}}</h2>			<h2>学校地址:{{address}}</h2>		</div>	</body> 	<script type="text/javascript">		Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。 		const vm = new Vue({			el:'#root',			data:{				name:'尚硅谷',				address:'宏福科技园'			}		})	</script></html>

image

事件的基本使用

<!DOCTYPE html><html>	<head>		<meta charset="UTF-8" />		<title>Vue中的数据代理</title>		<!-- 引入Vue -->		<script type="text/javascript" src="../js/vue.js"></script>	</head>	<body>		<!-- 				1.Vue中的数据代理:							通过vm对象来代理data对象中属性的操作(读/写)				2.Vue中数据代理的好处:							更加方便的操作data中的数据				3.基本原理:							通过Object.defineProperty()把data对象中所有属性添加到vm上。							为每一个添加到vm上的属性,都指定一个getter/setter。							在getter/setter内部去操作(读/写)data中对应的属性。		 -->		<!-- 准备好一个容器-->		<div id="root">			<h2>学校名称:{{name}}</h2>			<h2>学校地址:{{address}}</h2>		</div>	</body> 	<script type="text/javascript">		Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。 		const vm = new Vue({			el:'#root',			data:{				name:'尚硅谷',				address:'宏福科技园'			}		})	</script></html>

事件的修饰符

<!DOCTYPE html><html>	<head>		<meta charset="UTF-8" />		<title>事件的基本使用</title>		<!-- 引入Vue -->		<script type="text/javascript" src="../js/vue.js"></script>	</head>	<body>		<!-- 				事件的基本使用:							1.使用v-on:xxx 或 @xxx 绑定事件,其中xxx是事件名;							2.事件的回调需要配置在methods对象中,最终会在vm上;							3.methods中配置的函数,不要用箭头函数!否则this就不是vm了;							4.methods中配置的函数,都是被Vue所管理的函数,this的指向是vm 或 组件实例对象;							5.@click="demo" 和 @click="demo($event)" 效果一致,但后者可以传参;		-->		<!-- 准备好一个容器-->		<div id="root">			<h2>欢迎来到{{name}}学习</h2>			<!-- <button v-on:click="showInfo">点我提示信息</button> -->			<button @click="showInfo1">点我提示信息1(不传参)</button>			<button @click="showInfo2($event,66)">点我提示信息2(传参)</button>		</div>	</body> 	<script type="text/javascript">		Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。 		const vm = new Vue({			el:'#root',			data:{				name:'尚硅谷',			},			methods:{				showInfo1(event){					// console.log(event.target.innerText)					// console.log(this) //此处的this是vm					alert('同学你好!')				},				showInfo2(event,number){					console.log(event,number)					// console.log(event.target.innerText)					// console.log(this) //此处的this是vm					alert('同学你好!!')				}			}		})	</script></html>

键盘事件

<!DOCTYPE html><html>	<head>		<meta charset="UTF-8" />		<title>键盘事件</title>		<!-- 引入Vue -->		<script type="text/javascript" src="../js/vue.js"></script>	</head>	<body>		<!-- 				1.Vue中常用的按键别名:							回车 => enter							删除 => delete (捕获“删除”和“退格”键)							退出 => esc							空格 => space							换行 => tab (特殊,必须配合keydown去使用)							上 => up							下 => down							左 => left							右 => right 				2.Vue未提供别名的按键,可以使用按键原始的key值去绑定,但注意要转为kebab-case(短横线命名) 				3.系统修饰键(用法特殊):ctrl、alt、shift、meta							(1).配合keyup使用:按下修饰键的同时,再按下其他键,随后释放其他键,事件才被触发。							(2).配合keydown使用:正常触发事件。 				4.也可以使用keyCode去指定具体的按键(不推荐) 				5.Vue.config.keyCodes.自定义键名 = 键码,可以去定制按键别名		-->		<!-- 准备好一个容器-->		<div id="root">			<h2>欢迎来到{{name}}学习</h2>			<input type="text" placeholder="按下回车提示输入" @keydown.huiche="showInfo">		</div>	</body> 	<script type="text/javascript">		Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。		Vue.config.keyCodes.huiche = 13 //定义了一个别名按键 		new Vue({			el:'#root',			data:{				name:'尚硅谷'			},			methods: {				showInfo(e){					// console.log(e.key,e.keyCode)					console.log(e.target.value)				}			},		})	</script></html>

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注51zixue.net的更多内容!


下载地址:
带你搞懂js的深拷贝
Vue3使用Proxy实现数据监听的原因分析
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。