jquery对象控制type=radio的input问题解决方法:

前提:

<span style="white-space:pre">	</span><div>
	<span style="white-space:pre">	</span><input type="radio" name="messageType" value="automatic"/>自动发送 
		<input type="radio" name="messageType" value="manual"/>手动发送 
	</div>
              

                需求:

               界面上左边通过ajax获取消息列表,点击消息,右边呈现消息的具体信息,其中包括消息类型(自动发送还是手动发送,数据库保存的是AUTOMATIC和MANUAL)

      $(":radio[name='messageType']").removeAttr("checked");

               $(":radio[name='messageType'][value='" + message.type.toLowerCase() + "']").attr("checked", true);

              通过firdebug调试发现html中显示是没有问题的,但是没有赋值到radio.

             

                 解决思路:

//注意:这里用jquery控制radio会有问题,要使用js去做控制,如何将jquery对象转换为js对象.
//两种转换方式将一个jQuery对象转换成DOM对象:[index]和.get(index);
//jQuery对象转换为DOM对象.
//(1)jQuery对象是一个数据对象,可以通过[index]的方法来得到相应的DOM对象.
//如:var $v =$("#v"); //jQuery对象
//var v=$v[0]; //DOM对象
//alert(v.checked) //检测这个checkbox是否被选中
//(2)jQuery本身提供通过.get(index)方法得到相应的DOM对象.
//如:var $v=$("#v"); //jQuery对象
//var v=$v.get(0); //DOM对象
//alert(v.checked) //检测这个checkbox是否被选中
//DOM对象转成jQuery对象:
//对于已经是一个DOM对象,只需要用$()把DOM对象包装起来就可以获得一个jQuery对象,$(DOM对象).
//如:var v=document.getElementById("v"); //DOM对象
//var $v=$(v); //jQuery对象
//转换后,就可以任意使用jQuery的方法了。
//通过以上方法可以任意的相互转换jQuery对象和DOM对象.
//需要再强调注意的是:DOM对象才能使用DOM中的方法,jQuery对象是不可以用DOM中的方法.

       解决方案:
$(":radio[name='messageType'][value='" + message.type.toLowerCase() + "']")[0].checked = true;

               或

$(":radio[name='messageType'][value='" + message.type.toLowerCase() + "']").get(0).checked = true;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值