您的位置:首页 > Web前端 > JQuery

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

2015-02-09 12:22 405 查看
前提:

<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;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐