Skip to content

Radio 单选

平台兼容性

安卓iosweb微信小程序支付宝小程序QQ小程序
xxx

示例

vue
<template>
	<t-page class="p.30" title="单选">
		<t-card title="Radio 单选" class="mb.30" sub-title="表单或页面中实现单选功能,支持自定义样式、禁用状态、事件监听等特性,简化了表单操作,提高了用户体验。"></t-card>
		<template v-if="area==1">
			<t-section title="基础功能" class="mb.30"></t-section>
			<t-row class="tdb-tdr-mb.30-tdp-ffww">
				<t-radio ref="radio1" value="4" @click="checked(1)" :checked="true" type="primary">石榴</t-radio>
				<t-radio ref="radio2" @click="checked(2)" value="3" type="info">橙子</t-radio>
				<t-radio ref="radio3" @click="checked(3)" value="2" type="success">香蕉</t-radio>
				<t-radio ref="radio4" @click="checked(4)" value="3" type="error">橙子</t-radio>
				<t-radio ref="radio5" @click="checked(5)" value="5" type="warning">梨子</t-radio>
			</t-row>
		</template>
		<template v-if="area==2">
			<t-section title="按钮模式" class="mb.30"></t-section>
			<t-row class="tdr-mb.30-tdp-ffww">
				<t-radio class="mr.20" ref="radio1" @click="checked(1)" value="4" :checked="true" mode="button"
					type="primary">石榴</t-radio>
				<t-radio class="mr.20" ref="radio2" @click="checked(2)" value="3" mode="button" type="info">橙子</t-radio>
				<t-radio class="mr.20" ref="radio3" @click="checked(3)" mode="button" value="2"
					type="success">香蕉</t-radio>
				<t-radio class="mr.20" ref="radio4" @click="checked(4)" value="3" mode="button"
					type="error">橙子</t-radio>
				<t-radio class="mr.20" ref="radio5" @click="checked(5)" value="5" mode="button"
					type="warning">梨子</t-radio>
			</t-row>
		</template>
		<template v-if="area==3">
			<t-section title="列表模式" class="mb.30"></t-section>
			<t-col class="tdr-mb.30">
				<t-radio ref="radio1" @click="checked(1)" value="4" :checked="true" mode="cell"
					type="primary">石榴</t-radio>
				<t-radio ref="radio2" @click="checked(2)" value="3" mode="cell" type="info">橙子</t-radio>
				<t-radio ref="radio3" @click="checked(3)" mode="cell" value="2" type="success">香蕉</t-radio>
				<t-radio ref="radio4" @click="checked(4)" value="3" mode="cell" type="error">橙子</t-radio>
				<t-radio ref="radio5" @click="checked(5)" value="5" mode="cell" type="warning">梨子</t-radio>
			</t-col>
		</template>
		<template v-if="area==4">
			<t-section title="标签模式" class="mb.30"></t-section>
			<t-row class="tdr-mb.30-tdp-ffww">
				<t-radio class="mr.25-mb.30" ref="radio1" value="4" @click="checked(1)" mode="tag" type="primary"
					:checked="true" :disabled="true">石榴(禁用状态)</t-radio>
				<t-radio class="mr.25-mb.30" ref="radio2" value="3" @click="checked(2)" mode="tag"
					type="info">橙子</t-radio>
				<t-radio class="mr.25-mb.30" ref="radio3" mode="tag" @click="checked(3)" value="2"
					type="success">香蕉</t-radio>
				<t-radio class="mr.25-mb.30" ref="radio4" value="3" @click="checked(4)" mode="tag"
					type="error">橙子</t-radio>
				<t-radio class="mr.25-mb.30" ref="radio5" value="5" @click="checked(5)" mode="tag"
					type="warning">梨子</t-radio>
			</t-row>
		</template>
		<t-row class="tdb-tdr-mb.30-tdp-ffww">
			<t-button type="p" class="mr.30-mb.30" size="small" @click="area=1">基础功能</t-button>
			<t-button type="e" class="mr.30-mb.30" size="small" @click="area=2">按钮模式</t-button>
			<t-button type="s" class="mr.30-mb.30" size="small" @click="area=3">列表模式</t-button>
			<t-button type="w" class="mr.30-mb.30" size="small" @click="area=4">标签模式</t-button>
		</t-row>
	</t-page>
</template>

<script>
	export default {
		data() {
			return {
				area: 1
			};
		},
		methods: {
			checked(index : number) {
				for (let i = 1; i < 6; i++) {
					const ins = this.$refs['radio' + i] as TRadioComponentPublicInstance
					ins.setChecked(i == index)
				}
			}
		}
	}
</script>

Props

名称描述类型默认值
type组件场景String'info'
hover是否有鼠标悬停效果Booleantrue
value绑定的值String-
iconName图标名称String-
modelValue绑定的值,支持v-modelString-
activeColor选中时的颜色String-
inactiveColor未选中时的颜色String"#909399"
mode单选样式String'radio'

Events

名称描述
change当选中状态改变时触发
click当组件被点击时触发

Methods

名称描述
setChecked设置选中状态
wrapper点击事件包装器