Vue学习:v-model绑定文本框、单选按钮、下拉菜单、复选框等

v-model指令可以在组件上使用以实现双向绑定,之前学习过v-model绑定文本框和下拉菜单,今天把表单的几个控件单选按钮radio、复选框checkbox、多行文本框textarea都试着绑定了一下。

一、单行文本框和多行文本框

html 复制代码
<p>1.单行文本框</p>
用户名:<input type="text" v-model="inputMessage">
<p>您的用户名是:{{inputMessage}}</p>
<p>2.多行文本框</p>
<textarea v-model="textMessage" placeholder="请留言" rows="4" cols="80"></textarea>
<p>您的留言是:{{textMessage}}</p>
javascript 复制代码
<script type="text/javascript">
    const RootComp = {          //创建根组件
        data() {
            return {
                inputMessage: '',
                textMessage: '',
            }
        }
    }
    const vueApp = Vue.createApp(RootComp)   //创建Vue应用实例 
    const vm = vueApp.mount("#app")             //挂载vueApp
    console.log(vm.$data.inputMessage)          //输出data函数定义的inputMessage属性值 
</script>

运行效果如下。

二、单选按钮和下拉菜单

html 复制代码
<p>3.单选按钮</p>
<input type="radio" name="certificate" value="高" v-model="level"> 高级
<input type="radio" name="certificate" value="中" v-model="level"> 中级
<input type="radio" name="certificate" value="初" v-model="level"> 初级
<p>证书级别是:{{level}}</p>
<p>4.下拉菜单</p>
 所在城市:
 <select v-model="city">
   <option value="">请选择</option>
   <option value="beijing">北京</option>
   <option value="shanghai">上海</option>
   <option value="guangzhou">广州</option>
   <option value="shenzhen">深圳</option>
 </select>
 <p>所在城市是:{{city}}</p>
javascript 复制代码
<script type="text/javascript">
    const RootComp = {          //创建根组件
        data() {
            return {
                level: '高',
                city: '',
            }
        }
    }
    const vueApp = Vue.createApp(RootComp)   //创建Vue应用实例 
    const vm = vueApp.mount("#app")             //挂载vueApp
    console.log(vm.$data.inputMessage)          //输出data函数定义的inputMessage属性值 
</script>

运行效果如下。

三、复选框

html 复制代码
<p>5-1.复选框</p>
        <div>
            字节跳动:
            <input type="checkbox" v-model="byteDance" value="抖音">抖音
            <input type="checkbox" v-model="byteDance" value="西瓜视频">西瓜视频
            <input type="checkbox" v-model="byteDance" value="今日头条">今日头条
            <p>选中的复选框数量:{{ byteDance.length }}</p>
            <p>选中的复选框项:{{ byteDance }}</p>
        </div>
        <p>5-2.复选框(使用 v-for)生成复选框</p>
        <div>
            业余爱好:
            <label v-for="item in checks" :key="item.id">
                <input type="checkbox" v-model="checkOptions" :value="item.name">
                {{ item.name }}
            </label>
            <p>选中的复选框数量:{{ checkOptions.length }}</p>
            <p>选中的复选框项:{{ checkOptions }}</p>
        </div>
javascript 复制代码
<script type="text/javascript">
    const RootComp = {          //创建根组件
        data() {
            return {
                byteDance:[],
                checks: [
                    { id: 1, name: '游泳' },
                    { id: 2, name: '网球' },
                    { id: 3, name: '滑板' }
                ],
                checkOptions: [],
            }
        }
    }
    const vueApp = Vue.createApp(RootComp)   //创建Vue应用实例 
    const vm = vueApp.mount("#app")             //挂载vueApp
    console.log(vm.$data.inputMessage)          //输出data函数定义的inputMessage属性值 
</script>

运行效果如下。

完整代码如下:

html 复制代码
<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <title>v-model绑定input、textarea、radio、select、checkbox</title>
    <!--引入vue库-->
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
</head>

<body>
    <div id="app"> <!--挂载点-->
        <p>1.单行文本框</p>
        用户名:<input type="text" v-model="inputMessage">
        <p>您的用户名是:{{inputMessage}}</p>
        <p>2.多行文本框</p>
        <textarea v-model="textMessage" placeholder="请留言" rows="4" cols="80"></textarea>
        <p>您的留言是:{{textMessage}}</p>
        <p>3.单选按钮</p>
        <input type="radio" name="certificate" value="高" v-model="level"> 高级
        <input type="radio" name="certificate" value="中" v-model="level"> 中级
        <input type="radio" name="certificate" value="初" v-model="level"> 初级
        <p>证书级别是:{{level}}</p>
        <p>4.下拉菜单</p>
        所在城市:
        <select v-model="city">
            <option value="">请选择</option>
            <option value="beijing">北京</option>
            <option value="shanghai">上海</option>
            <option value="guangzhou">广州</option>
            <option value="shenzhen">深圳</option>
        </select>
        <p>所在城市是:{{city}}</p>
        <p>5-1.复选框</p>
        <div>
            字节跳动:
            <input type="checkbox" v-model="byteDance" value="抖音">抖音
            <input type="checkbox" v-model="byteDance" value="西瓜视频">西瓜视频
            <input type="checkbox" v-model="byteDance" value="今日头条">今日头条
            <p>选中的复选框数量:{{ byteDance.length }}</p>
            <p>选中的复选框项:{{ byteDance }}</p>
        </div>
        <p>5-2.复选框(使用 v-for)生成复选框</p>
        <div>
            业余爱好:
            <label v-for="item in checks" :key="item.id">
                <input type="checkbox" v-model="checkOptions" :value="item.name">
                {{ item.name }}
            </label>
            <p>选中的复选框数量:{{ checkOptions.length }}</p>
            <p>选中的复选框项:{{ checkOptions }}</p>
        </div>
    </div>
</body>

<script type="text/javascript">
    const RootComp = {          //创建根组件
        data() {
            return {
                inputMessage: '',
                textMessage: '',
                level: '高',
                city: '',
                byteDance:[],
                checks: [
                    { id: 1, name: '游泳' },
                    { id: 2, name: '网球' },
                    { id: 3, name: '滑板' }
                ],
                checkOptions: [],
            }
        }
    }
    const vueApp = Vue.createApp(RootComp)   //创建Vue应用实例 
    const vm = vueApp.mount("#app")          //挂载vueApp
    console.log(vm.$data.inputMessage)       //输出data函数定义的inputMessage属性值 
</script>

</html>
相关推荐
Bellafu66639 分钟前
selenium 常用xpath写法
前端·selenium·测试工具
blackorbird3 小时前
Edge 浏览器 IE 模式成攻击突破口:黑客借仿冒网站诱导攻击
前端·edge
谷歌开发者4 小时前
Web 开发指向标 | Chrome 开发者工具学习资源 (一)
前端·chrome·学习
名字越长技术越强4 小时前
Chrome和IE获取本机ip地址
前端
天***88964 小时前
Chrome 安装失败且提示“无可用的更新” 或 “与服务器的连接意外终止”,Chrome 离线版下载安装教程
前端·chrome
半梦半醒*4 小时前
zabbix安装
linux·运维·前端·网络·zabbix
清羽_ls5 小时前
React Hooks 核心规则&自定义 Hooks
前端·react.js·hooks
你的人类朋友5 小时前
“签名”这个概念是非对称加密独有的吗?
前端·后端·安全
西陵5 小时前
Nx带来极致的前端开发体验——任务缓存
前端·javascript·架构
本郡主是喵6 小时前
用 TypeScript 进行 Truffle 测试
学习·区块链