uniapp的单选框
时间: 2023-09-30 09:07:15 浏览: 108
uniapp的单选框可以通过使用radio组件来实现。在模拟实现多选框的思路中,可以使用radio组件来创建单选框。你需要为每个选项创建一个label标签,并在其中使用radio组件,同时使用v-for指令遍历radioGroup数组来生成选项。在label标签中,你可以使用:value绑定值来指定radio组件的值,并使用:checked属性来判断当前选项是否被选中。当单选按钮发生改变时,可以通过@change事件来调用对应的方法来处理选中值的变化。在方法中,可以通过e.detail.value获取选中的值,并将其赋值给activeRadio变量。以下是一个示例代码:
```
<template>
<view>
<radio-group @change="chang">
<label v-for="item in radioGroup" :key="item">
<radio :value="item" :checked="item==activeRadio" />{{item}}
</label>
</radio-group>
</view>
</template>
<script>
export default {
data() {
return {
activeRadio: '',
radioGroup: ['苹果', '香蕉', '梨', '西红柿', '西瓜']
}
},
methods: {
chang(e) {
this.activeRadio = e.detail.value;
console.log(this.activeRadio);
}
}
}
</script>
```
在实际场景中,比如男女单选框,你可以使用radio-group组件,并为每个选项创建一个label标签。在label标签中,使用radio组件来表示选项,并通过:value绑定值来指定radio组件的值。通过:checked属性来判断当前选项是否被选中。当单选按钮发生改变时,可以使用@change事件来调用对应的方法来处理选中值的变化。以下是一个示例代码:
```
<template>
<radio-group @change="radioChange">
<label class="radio">
<radio style="zoom: 0.8;" :color="roleColor" value="1" :checked="sex == '1'" />男
</label>
<label class="radio" style="margin-left: 15%;">
<radio style="zoom: 0.8;" :color="roleColor" value="2" :checked="sex == '2'" />女
</label>
</radio-group>
</template>
<script>
export default {
data() {
return {
sex: "",
}
},
methods: {
radioChange(evt) {
this.sex = evt.detail.value;
},
}
}
</script>
```
这样,你就可以通过使用uniapp的radio组件来创建单选框了。
阅读全文