vue中怎么获取radio的选中值 、选中状态?

Vue.js 专栏收录该内容
40 篇文章 0 订阅
方法1:

设置v-model

<!DOCTYPE html>  
<html>  
<head>  
    <meta charset="utf-8">  
    <title>test</title>  
    <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>  
</head>  
<body>  
    <div id='app'>
      <input type="radio" name="test" v-for="(item,index) in list" :value="item.value" v-model="checkedValue">
      <button @click="test">获取选中的值</button>
    </div>
<script>
var vm = new Vue({
  el:'#app', 
  data(){
    return{
      checkedValue:'',
      list:[{value:1},{value:2},{value:3}]
    }
  },
  methods:{
    test(){
      console.log('被选中的值为:'+this.checkedValue)
    }
  }
});
</script>
</body>  
</html>  
方法2:

如果不想每次点击都判断,那就提供一个思路,定义一个radio数组list,每项设置一个isCheck标识,循环该数组渲染radio,点击按钮时再统一去判断

<!DOCTYPE html>  
<html>  
<head>  
    <meta charset="utf-8">  
    <title>test</title>  
    <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>  
</head>  
<body>  
    <div id='app'>
      <input type="radio" name="test" v-for="(item,index) in list" :value="item.value" :checked="item.isCheck" @change="changeInput(index)">
      <button @click="test">获取选中的值</button>
    </div>
<script>
var vm = new Vue({
  el:'#app', 
  data(){
    return{
      list:[{value:1,isCheck:false},{value:2,isCheck:false},{value:3,isCheck:false}]
    }
  },
  methods:{
    changeInput(index){
      this.list.map((v,i)=>{ 
        if(i==index){
          v.isCheck = true
        }else{
          v.isCheck = false
        }
      })
    },
    test(){
      this.list.map((v,i)=>{
        if(v.isCheck){
          console.log('被选中的值为:'+v.value)
        }
      })
    }
  }
});
</script>
</body>  
</html>  
来自: https://segmentfault.com/q/1010000012785101
  • 6
    点赞
  • 3
    评论
  • 17
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

相关推荐
©️2020 CSDN 皮肤主题: 撸撸猫 设计师:马嘣嘣 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值