vue如何实现表单多选并且获取其中的值

 更新时间:2023年07月03日 09:49:48   作者:web前端 zxp  
这篇文章主要介绍了vue如何实现表单多选并且获取其中的值问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

vue实现表单多选并且获取其中的值

说明

使用 v-model 指令 结合 name / value 使用

需要你的 data 里面的数据类型为 数组

代码说明

为什么会是 v-model.number ?

这是将它的值固定为 数字类型,否则你获取到的就是字符串

<div id="root">
    <input type="checkbox" v-model.number="hobby" name="hobby" value="1">学习
    <input type="checkbox" v-model.number="hobby" name="hobby" value="2">游泳
    <input type="checkbox" v-model.number="hobby" name="hobby" value="3">下棋
    <input type="checkbox" v-model.number="hobby" name="hobby" value="4">乒乓球
    <div>{{hobby}}</div>
</div>
</body>
<script>
    new Vue({
        el:"#root",
        data:{
            hobby:[4]  //默认的选择第四个,你可以不选默认项
        },
    })
</script>

它现在的值就是 data 数组中的数据,想要获得数据直接使用这个数组

vue获取表单数据——input、radio、checkbox、select、textarea

获取表单数据(案例)

1.效果

注意:这个案例只是简单的再前端输出获取的表单内容,并没有提交到后台

2.代码

<div class="root">
        <form @submit.prevent="demo">
            <!-- trim去掉首尾空格,中间的空格去不掉 -->
            账号:<input type="text" v-model.trim="userInfo.account"> <br><br>
            密码:<input type="text" v-model="userInfo.password"><br><br>
            <!-- number输入的字符串转换为数字 -->
            年龄:<input type="number" v-model.number="userInfo.age"><br><br>
            性别:
            男<input type="radio" v-model="userInfo.sex" name="sex" value="男">
            女<input type="radio" v-model="userInfo.sex" name="sex" value="女"><br><br>
            爱好:
            学习<input type="checkbox" v-model="userInfo.hobby" value="学习">
            打游戏<input type="checkbox" v-model="userInfo.hobby" value="打游戏">
            吃饭<input type="checkbox" v-model="userInfo.hobby" value="吃饭">
            <br><br>
            选择地址:
            <select v-model="userInfo.city">
                <option value="北京">北京</option>
                <option value="上海">上海</option>
                <option value="深圳">深圳</option>
                <option value="武汉">武汉</option>
            </select> <br><br>
            其他信息:
            <!-- lazy失去焦点再获取数据 -->
            <textarea v-model.lazy="userInfo.other" cols="30" rows="10"></textarea>
            <br><br>
            <input type="checkbox" v-model="userInfo.agree">
            阅读并接受<a href="www.baidu.com" rel="external nofollow" >《用户协议》</a>
            <button>提交</button>
        </form>
    </div>
new Vue({
            el: '.root',
            data() {
                return {
                    userInfo: {
                        account: '',
                        password: '',
                        sex: '',
                        hobby: [],
                        city: '北京',
                        other: '',
                        agree: '',
                        age: ''
                    }
                }
            },
            methods: {
                demo() {
                    //JSON.stringify() 将数据转换为json字符串
                    console.log(JSON.stringify(this.userInfo));
                }
            },
        })

心得

收集表单数据:

1.<input type=“text”/>,则v-model收集的是value值,用户输入的就是value值。

<input type=“radio”/>,则v-model收集的是value值,且要给标签配置value值。

2.<input type=“checkbox”/>没有配置input的value属性,那么收集的就是checked(勾选 or 未勾选,是布尔值)

3.配置input的value属性:

  • (1)v-model的初始值是非数组,那么收集的就是checked(勾选 or 未勾选,是布尔值)
  • (2)v-model的初始值是数组,那么收集的的就是value组成的数组

4.备注:v-model的三个修饰符:

  • lazy:失去焦点再收集数据
  • number:输入字符串转为有效的数字
  • trim:输入首尾空格过滤

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Vue.Js中的$watch()方法总结

    Vue.Js中的$watch()方法总结

    这篇文章主要给大家介绍了在Vue.Js中的$watch()方法的相关资料,文中通过示例代码介绍的非常详细,对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-03-03
  • 对Vue2 自定义全局指令Vue.directive和指令的生命周期介绍

    对Vue2 自定义全局指令Vue.directive和指令的生命周期介绍

    今天小编就为大家分享一篇对Vue2 自定义全局指令Vue.directive和指令的生命周期介绍,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-08-08
  • vue解决跨域路由冲突问题思路解析

    vue解决跨域路由冲突问题思路解析

    Vue.js(读音 /vju&#720;/, 类似于 view) 是一套构建用户界面的渐进式框架。本文给大家详细介绍了vue解决跨域路由冲突问题思路解析,需要的朋友参考下吧
    2017-11-11
  • 在Vue中使用JSONP进行跨域数据传输的完整指南

    在Vue中使用JSONP进行跨域数据传输的完整指南

    本文将介绍JSONP(JSON with Padding)的原理和用法,以及如何使用JSONP进行跨域数据传输,详细解释JSONP的工作原理,并提供前端和后端的代码示例,帮助你理解和实践JSONP跨域请求,需要的朋友可以参考下
    2023-06-06
  • vue使用keep-alive保持滚动条位置的实现方法

    vue使用keep-alive保持滚动条位置的实现方法

    这篇文章主要介绍了vue使用keep-alive保持滚动条位置的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • vue项目打包部署到nginx后css样式失效的问题及解决方法

    vue项目打包部署到nginx后css样式失效的问题及解决方法

    我将自己的前端Vue项目,经过build生成的dist文件夹copy到nginx的html文件夹中,然后写了配置文件,运行访问后发现页面css样式没有加载到,下面给大家介绍vue项目打包部署到nginx后css样式失效的问题及解决方法,感兴趣的朋友一起看看吧
    2024-12-12
  • Vue.js 父子组件通讯开发实例

    Vue.js 父子组件通讯开发实例

    这篇文章主要介绍了Vue.js 父子组件通讯开发实例的相关资料,本文介绍的非常详细,具有参考借鉴价值,需要的朋友可以参考下
    2016-09-09
  • Vue导入Echarts实现折线图

    Vue导入Echarts实现折线图

    这篇文章主要给大家介绍了关于vue+echarts实现折线图的方法与注意事项,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-12-12
  • vue中el-date-picker type=daterange日期清空时不回显的解决

    vue中el-date-picker type=daterange日期清空时不回显的解决

    这篇文章主要介绍了vue中el-date-picker type=daterange日期清空时不回显的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • vue.js删除列表中的一行

    vue.js删除列表中的一行

    这篇文章给大家分享了vue.js删除列表中的一行的实例操作以及代码分享,有兴趣的朋友参考下。
    2018-06-06

最新评论