js的写法:document.getElementById('save').disabled=true;
在jquery中我是这样写的$("#save").disabled = true; 为何没效果呢
javascript
这个是典型的问题,其实由于$("#save")出来的实际上是jQuery对象,而不是普通DOM对象
解决方法有2:
1,用JQ写法,$("#save").attr("disabled","true");
2,转成DOM写法$("#save")[0].disabled=true;
固然,$("#save")[0]也能够写成$("#save").get(0)。他返回的也是DOM元素
$("#save").eq(0)获得的仍是jq对象 html
若是给定表示 DOM 元素集合的 jQuery 对象,.eq() 方法会用集合中的一个元素构造一个新的 jQuery 对象。java
$(dom对象)就能获得一个jq对象jquery
例如:数组
$("#color").html();//获取id为color的元素内的html代码,html()是jQuery特有的方法;
它等同于:
document.getElementById("color").innerHTML;dom
DOM对象就是javascript固有的一些对象。DOM对象能使用javascript固有的方法,可是不能使用jQuery里面的方法。ide
例如$("#id").innerHTML 和$("#id").checked之类的写法都是错误的,能够用$("#id").html()和$("#id").attr("checked")之类的 jQuery方法来代替。spa
var domObj =document.getElementById("id"); //DOM对象
var $obj =$("#id"); //jQuery对象;htm
jQuery对象和DOM对象的相互转换对象
jQuery对象转换成DOM对象
jquery提供了两种方法将一个jquery对象转换成一个dom对象,即[index]和get(index)。可能有人会以为奇怪,怎么是用下标呢,没错,jquery对象就是一个数组对象.
下面代码将演示一个jquery对象转换成dom对象,再使用dom对象的方法
代码以下:
var$cr=$("#cr"); //jquery对象
var cr = $cr[0]; //dom对象 也可写成 var cr=$cr.get(0);
alert(cr.checked); //检测这个checkbox是否给选中
dom对象转换成jquery对象
对于一个dom对象,只须要用$()把dom对象包装起来,就能够得到一个jquery对象了,方法为$(dom对象);
复制代码 代码以下:
varcr=document.getElementById("cr"); //dom对象
var $cr = $(cr); //转换成jquery对象
转换后能够任意使用jquery中的方法