zoukankan      html  css  js  c++  java
  • vue修饰符

    vue修饰符:
    	《1》表单修饰符
    	《2》事件修饰符
    	《3》鼠标、按钮修饰符
    	《4》v-bind修饰符
    	《5》注意:修饰符可以同时使用多个,但是可能会因为顺序而有所不同
    	
    《1》表单修饰符
    	(a)v-model.lazy   = "value"
    	
    	(b)v-model.trim   = "value"
    	
    	(c)v-model.number = "value"
    		如果你先输入数字,那它就会限制你输入的只能是数字。
    		如果你先输入字符串,那它就相当于没有加.number
    
    		
    《2》事件修饰符
    	@click.prevent  		//阻止事件的默认行为
    	@click.prevent.self 	//会阻止所有的点击
    	@click.self.prevent 	//只会阻止对元素自身的点击
    	
    	
    	@click.once             //只能触发一次
    	
    	
    	@click.native			//小组件绑定事件,作用就是把一个vue组件转化为一个普通的HTML标签
    							//注意:使用.native修饰符来操作普通HTML标签是会令事件失效的
    	
    	
    	@click.self				//只当事件是从(事件绑定的元素本身)触发时才触发回调
    								//触发blue元素时才能触发shout(2)
    								<div class="blue" @click.self="shout(2)">
    								  <button @click="shout(1)">ok</button>
    								</div>
    								
    								
    	@click.stop 			//阻止事件冒泡(由内向外)
    	
    	
    	@click.capture			//事件捕获(事件触发从包含这个元素的顶层开始往下触发)
    							//捕获阶段--目标阶段--冒泡阶段(结果:1,2,4,3)
    								<div @click.capture="shout(1)">
    									obj1
    									<div @click.capture="shout(2)">
    										obj2
    									<div @click="shout(3)">
    										obj3
    									  <div @click="shout(4)">
    										obj4
    									  </div>
    									</div>
    								</div>
    								
    		
    	@scroll.passive			//滚动事件的默认行为 (即滚动行为) 将会立即触发,而不会等待 'onScroll' 完成
    							//这其中包含 'event.preventDefault()' 的情况
    							
    	
    《3》鼠标、按钮修饰符
    	//event.keyCode可以直接是数字
    		@keyup.keyCode	 |	@keydown.keyCode
    	
    	//普通键
    		.enter
    		.tab
    		.delete //(捕获“删除”和“退格”键)
    		.space
    		.esc
    		.up
    		.down
    		.left
    		.right
    		
    	//系统修饰键
    		.ctrl
    		.shift
    		.alt
    		.meta
    		.exact
    	
    	注意:
    		1.可以通过全局 config.keyCodes 对象自定义按键修饰符别名
    			Vue.config.keyCodes.f1 = 112
    			
    		2.普通键和系统修饰键
    			系统修饰键:与普通键不同的是需要和其他键码链接起来使用才起作用
    			
    				@keyup.ctrl.13 		//ctrl和enter键同时按
    			
    			但是如果是鼠标事件,那就可以单独使用系统修饰符
    				//先按ctrl键,在移动鼠标触发
    				//存在问题:当先按下ctrl键和shift键或其他系统修饰符,在移动鼠标也能触发。解决看.exact
    				@mouseover.ctrl	 |  @mousedown.ctrl    
    		
    		3..exact
    			只需要或者只能按一个系统修饰键来触发,场景:比如制作一些快捷键时候
    			@mouseover.ctrl.exact
    			
    			
    《4》v-bind修饰符		
    	(1).sync	
    		场景:需要对一个 prop 进行"双向绑定"。
    			  不幸的是,真正的双向绑定会带来维护上的问题,因为子组件可以修改父组件,且在父组件和子组件都没有明显的改动来源。
    		
    		(a)普通方式:
    			//父亲组件
    			<comp :myMessage="bar" @update:myMessage="func"></comp>
    			//js
    			func(e){
    			 this.bar = e;
    			}
    
    			//子组件js
    			func2(){
    			  this.$emit('update:myMessage',params);
    			}
    		
    		(b).sync方式:
    			//父组件
    			<comp :myMessage.sync="bar"></comp>
    			//子组件
    			this.$emit('update:myMessage',params);
    			
    		注意:
    			1、使用sync的时候,子组件传递的事件名必须为update:value,其中value必须与子组件中props中声明的名称完全一致(如上例中的myMessage,不能使用my-message)
    			2、注意带有 .sync 修饰符的 v-bind 不能和表达式一起使用 (例如 v-bind:title.sync=”doc.title + ‘!’” 是无效的)。取而代之的是,你只能提供你想要绑定的属性名,类似 v-model。
    			3、将 v-bind.sync 用在一个字面量的对象上,例如 v-bind.sync=”{ title: doc.title }”,是无法正常工作的,因为在解析一个像这样的复杂表达式的时候,有很多边缘情况需要考虑。
    		
    	(2).prop
    		Property:节点对象在内存中存储的属性,可以访问和设置。
    		Attribute:节点对象的其中一个属性( property ),值是一个对象。
    		可以通过点访问法 document.getElementById('xx').attributes 或者 document.getElementById('xx').getAttributes('xx') 读取,通过 document.getElementById('xx').setAttribute('xx',value) 新增和修改。
    		在标签里定义的所有属性包括 HTML 属性和自定义属性都会在 attributes 对象里以键值对的方式存在。
    	
    		//这里的id,value,style都属于property
    		//index属于attribute
    		//id、title等既是属性,也是特性。修改属性,其对应的特性会发生改变;修改特性,属性也会改变
    		<input id="uid" title="title1" value="1" :index="index">
    		//input.index === undefined
    		//input.attributes.index === this.index
    	
    		可以看到:如果直接使用v-bind绑定,则默认会绑定到dom节点的attribute。
    			1.通过自定义属性存储变量,避免暴露数据
    			2.防止污染 HTML 结构
    		
    		我们可以使用这个修饰符,如下:
    			<input id="uid" title="title1" value="1" :index.prop="index">
    			//input.index === this.index
    			//input.attributes.index === undefined
    		
    	(3).camel
    		由于HTML 特性是不区分大小写的。
    			<svg :viewBox="viewBox"></svg>
    		实际上会渲染为:
    			<svg viewbox="viewBox"></svg>
    		这将导致渲染失败,因为 SVG 标签只认 viewBox,却不知道 viewbox 是什么。
    		如果我们使用.camel修饰符,那它就会被渲染为驼峰名。
    		
    		但是如果你使用字符串模版,则没有这些限制。
    			new Vue({
    			  template: '<svg :viewBox="viewBox"></svg>'
    			})
    

      

  • 相关阅读:
    JS 实现数据分割1,123,456
    JS屏蔽键盘相关事件
    地图坐标转屏幕坐标
    对xml格式的字符串的一些操作
    ListView_Adpter
    单元测试(Android)_JUnit
    调用系统拍照
    获取手机SD卡的剩余容量(MB)
    数据库的基本操作
    临时修改模拟器手机运行内存和手机内存(不是SD卡内存)
  • 原文地址:https://www.cnblogs.com/changxue/p/12202206.html
Copyright © 2011-2022 走看看