Vue的双向绑定一(v-model和输入框)

Vue.js通过v-model指令实现表单元素的双向数据绑定。在输入框、文本域等元素上使用v-model,输入内容会实时同步到绑定的数据,并反映在视图中。即使初始value值改变,v-model也会保持数据同步。中文输入法输入时,Vue通常在选定词后更新数据,但可以使用@input事件监听实时更新。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Vue的双向绑定一(v-model和输入框)

vue.js提供了v-model指令,用于在表单类元素上双向绑定数据。
比如:在输入框上使用时,输入框的内容会实时映射到绑定的数据上。

<div id="app9">
	<input type="text" v-model="message" />
	<p>输入的数据是:{{message}}</p>
</div>
<script type="text/javascript">
	var app9 = new Vue({
		el:"#app9",
		data:{
			message:''
		}
	})
</script>
  1. 在输入框输入的同时{{message}}也会实时将内容渲染在视图中。对文本与textarea也是同样的用法。
  2. 注意:使用v-model后,表单控件显示的值只依赖所绑定的数据,不再关心初始化时的value值,对于在之间插入的值也会生效。
  3. 使用v-model时,如果是用中文输入法输入中文,一般在没有选定词之前,也就是拼音阶段,Vue是不会更新数据的,当敲下时才会触发更新。如果希望总是实时更新,可以用==@input==来代替v-model。
    事实上,v-model也是一个特殊的语法糖,只不过他会在不同的表单上智能处理。
<div id="app10">
	<input type="text" @input="handInput" />
	<p>输入的数据是:{{message}}</p>
</div>
<script type="text/javascript">
	var app9 = new Vue({
		el:"#app10",
		data:{
			message:''
		},
		methods:{	
			handInput:function(e){		
				//方法里的this ---> #app10
				this.message = e.target.value		
			}
		}
	})
</script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值