bootstrap radio动态选中

最近用bootstrap 3做项目,发现一个超级恶心的问题,信息修改时bootstrap的radio怎么都无法动态选中,网上找了很多方法都不行。最后通过以下方式解决了。
代码如下

html定义

<label class="col-sm-2 control-label">性别</label>
<div class="col-sm-3">
	<label for="genderM" class="radio-inline">
		<input type="radio" name="userGender" id="genderM" value="M"></label>
	<label for="genderF" class="radio-inline">
		<input type="radio" name="userGender" id="genderF" value="F"></label>
	<label for="genderX" class="radio-inline">
		<input type="radio" name="userGender" id="genderX" value="X">保密
	</label>
</div>

JS动态选中

$.ajax({
	url : "/flashsale/user/" + uId,
	async : false,
	type : "GET",
	success : function(result) {
		if (result.success) {
			var userInfo = result.data[0];
			for (var name in userInfo) {
				var value = userInfo[name];
				
				// 性别动态赋值
				if ("userGender" == name) {
					var radios = document.getElementsByName("userGender");
					console.log(radios);
					if ("M" == value) {
						radios[0].checked = true;
					} else if("F" == value) {
						radios[1].checked = true;
					}  else {
						radios[2].checked = true;
					}
				} else {
		        	$("#userForm #" + name).val(value);
		        }
			}
		} else {
			toastr.error('获取用户['+ userId + ']信息失败,原因:' + result.errorMessage);
		}
	},
	error : function(result) {
		toastr.error('获取用户['+ userId + ']信息失败,原因:' + result.errorMessage);
	}
});

效果图
在这里插入图片描述
第一条记录为女,则选中女
在这里插入图片描述
第二条男,则选中男
在这里插入图片描述

还有一个注意点:bootstrap的radio由一层label包着,有时看似选中了,可是Form提交后却取不到值,这个其实是假的选中,选中的是label的样式按钮而不是radio的。所以radio要加id,然后label标签需要加for属性指向radio的id才能真正选中radio,如下

<label class="col-sm-2 control-label">性别</label>
<div class="col-sm-3">
	<label for="genderM" class="radio-inline">
		<input type="radio" name="userGender" id="genderM" value="M"></label>
	<label for="genderF" class="radio-inline">
		<input type="radio" name="userGender" id="genderF" value="F"></label>
	<label for="genderX" class="radio-inline">
		<input type="radio" name="userGender" id="genderX" value="X">保密
	</label>
</div>
  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值