单向数据绑定:当数据发生改变时,视图会自动更新,但当用户手动更改input的值,数据不会自动更新;
双向数据绑定:当数据发生改变时,视图会自动更新,但当用户手动更改input的值,数据也会自动更新。
一、v-model
1、双向数据绑定
双向数据绑定<input type="text" v-model="web.text">
2、单选框
<input type="radio" v-model="web.radio" value="星期一">星期一
<input type="radio" v-model="web.radio" value="星期二">星期二
3、复选框
<input type="checkbox" v-model="web.checkbox" value="星期一">星期一
<input type="checkbox" v-model="web.checkbox" value="星期二">星期二
<input type="checkbox" v-model="web.checkbox" value="星期三">星期三
4、记住密码
<input type="checkbox" v-model="web.remember">记住密码
5、下拉框
对于<select>,v-model绑定的是select元素中选中的项。
<select v-model="web.select">
<option value="">请选择</option>
<option value="星期一">星期一</option>
<option value="星期二">星期二</option>
<option value="星期三">星期三</option>
</select>
完整示例代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<!-- <script src="vue.global.js"></script> -->
</head>
<body>
<div id="app">
<h3>文本框:{{web.text}}</h3>
<h3>单选框:{{web.radio}}</h3>
<h3>复选框:{{web.checkbox}}</h3>
<h3>记住密码:{{web.remember}}</h3>
<h3>下拉框:{{web.select}}</h3>
<hr>
单向数据绑定<input type="text" :value="web.text"><br>
双向数据绑定<input type="text" v-model="web.text">
<hr>
<!-- 单选框 -->
<input type="radio" v-model="web.radio" value="星期一">星期一
<input type="radio" v-model="web.radio" value="星期二">星期二
<hr>
<!-- 复选框 -->
<input type="checkbox" v-model="web.checkbox" value="星期一">星期一
<input type="checkbox" v-model="web.checkbox" value="星期二">星期二
<input type="checkbox" v-model="web.checkbox" value="星期三">星期三
<hr>
<!-- 记住密码 -->
<input type="checkbox" v-model="web.remember">记住密码
<hr>
<!-- 下拉框 -->
<select v-model="web.select">
<option value="">请选择</option>
<option value="星期一">星期一</option>
<option value="星期二">星期二</option>
<option value="星期三">星期三</option>
</select>
</div>
<script type="module">
import {createApp, reactive} from './vue.esm-browser.js'
// const {createApp, reactive} = Vue
createApp({
// setup选项,用于设置响应式数据和方法等
setup(){
const web = reactive({
text:"denglu.com",
radio:"",
checkbox:[],
remember:false,
select:""
})
return{
web
}
}
}).mount("#app")
// mount为挂载
</script>
</body>
</html>
二、v-model修饰符
实现功能:在失去焦点或按下回车键之后再渲染。
<input type="text" v-model.lazy="web.url">
实现功能:输入框的值转换为数字类型
<input type="text" v-model.number="web.user">
实现功能:去除收尾空格
<input type="text" v-model.trim="web.url">