zl程序教程

您现在的位置是:首页 >  前端

当前栏目

jQuery实用函数用法总结

jQuery 函数 用法 总结 实用
2023-06-13 09:15:44 时间

本文以实例的形式总结了jQuery的常见实用函数。分享给大家供大家参考之用。具体示例如下:

1.修剪字符串

$("#id").val($.trim($("#someid").val()))

2.遍历集合

可能这样写:

varanArray=["one","two"];
for(varn=0;n<anArray.length;n++){

}

还有可能这样写:

varanObject={one:1,two:2};
for(varpinanObject){

}

但有了$.each函数后,就可以这样写了:

varanArray=["one","two"];
$.each(anArray,funtion(n,value){

})
varanObject={one:1,two:2};
$.each(anObjct,function(name,value){

})

3.筛选数组

使用$.grep()方法能筛选数组。先来看grep方法的定义:

grep:function(elems,callback,inv){
varret=[],retVal;
inv=!!inv;
for(vari=0;length=elems.length;i<length;i++){
retVal=!!callback(elems[i],i)
if(inv!==retVal){
ret.push(elems[i]);
}
}
returnret;
}

以上示例中:
①grep方法的第二个参数是回调函数,该回调函数接收2个参数,一个是数组的元素,一个是数组的索引。
②grep方法的第三个参数inv,默认情况下是undefined,所以!!inv为false,即inv的默认值是false

举例1:int类型数组

vararr=[1,2,3,4,5,6];
arr=$.grep(arr,function(val,index){
returnval>3;
})
console.log(arr);//结果是:456

如果把grep的第三个参数显式地设置为true,结果怎样呢?

vararr=[1,2,3,4,5,6];
arr=$.grep(arr,function(val,index){
returnval>3;
},true)
console.log(arr);//结果是:123

可见,当把grep方法的第三个参数设置为true后,会把不符合回调函数的数组元素过滤出来。

举例2:object类型数组

vararr=[
{
first:"Jeffrey",
last:"Way"
},{
first:"Allison",
last:"Way"
},{
first:"John",
last:"Doe"
},{
first:"Thomas",
last:"Way"
};
arr=$.grep(arr,function(obj,index){
returnobj.last==="Way";
});
console.log(arr);
];

4.转换数组

使用$.map(arr,callback)为数组的每一个元素调用回调函数,并返回一个新的数组

给数组的每一个元素加1:

varoneBased=$.map([0,1,2,3,4],function(value){returnvalue+1;})

把字符串数组转换成整型数字数组,判断数组元素是否是数字:

varstrings=["1","2","3","4","S","6"];
varvalues=$.map(strings,function(value){
varresult=newNumber(value);
returnisNaN(result)?null:result;
})

把转换后的数组合并到原先的数组中:

varchars=$.map(["this","that"],function(value){returnvalue.split("")});

5.返回数组元素的索引

使用$.inArray(value,array)返回传入的值第一次出现的下标,即索引。

varindex=$.inArray(2,[1,2,3]);

6.将对象转换成数组

$.makeArray(object)将传入类似数组的对象转换成Javascript数组。

<div>First</div>
<div>Second</div>
<div>Third</div>
<div>Fourth</div>
<script>
varelems=document.getElementsByTagName("div");
vararr=jQuery.makeArray(elems);
arr.reverse();
$(arr).appendTo(document.body);
</script>

7.得到不含重复元素的数组

使用$.unique(array)返回由原始数组中不重复的元素组成的数组。

<div>Thereare6divsinthisdocument.</div>
<div></div>
<divclass="dup"></div>
<divclass="dup"></div>
<divclass="dup"></div>
<div></div>
//把到所有div,get方法转换成javascript数组,总共6个div
vardivs=$("div").get();
//再把3个class名为dup的div合并到前面的6个div
divs=divs.concat($(".dup").get());
alert(divs.length);//9个div
//过滤去掉重复
divs=jQuery.unqiue(divs);
alert(divs.length);//6个div

8.合并2个数组

$.merge(array1,array2)把第二个数组合并到第一个数组中,并返回第一个数组。

vara1=[1,2];
vara2=[2,3];
$.merge(a1,a2);
console.log(a1);//[1,2,2,3]

9.把对象序列化成查询字符串

$.param(params)把传入的jquery对象或javascript对象转换成字符串形式。

$(document).ready(function(){
personObj=newObject();
personObj.firstname="John";
personObj.lastname="Doe";
personObj.age=50;
personObj.eyecolor="blue";
$("button").click(function(){
$("div").text($.param(personObj));
});
});

结果:firstname=John&lastname=Doe&age=50&eyecolor=blue

10.一些判断函数

$.isArray(o)如果o是javascript数组,则返回true,如果是类似数组的jquery对象数组,返回false
$.isEmptyObject(o)如果o是不包含属性的javascript对象,则返回true
$.isFunction(o)如果o是javascript函数就返回true
$.isPlainObject(o)如果o是通过{}或newObject()创建的对象,则返回true
$.isXMLDoc(node)如果node是XML文档或者是XML文档中的节点,则返回true

11.判断一个元素是否包含在另外一个元素中

$.contains(container,containee)第二个参数是被包含

$.contains(document.documentElement,document.body);//true
$.contains(document.body,document.documentElement);//false

12.把值存储到某元素上

$.data(element,key,value)第一个是javascript对象,第二、第三个是键值。

//得到一个div的javascript对象
vardiv=$("div")[0];
//把键值存储到div上
jQuery.data(div,"test",{
first:16,
last:"pizza"
})
//根据键读出值
jQuery.data(div,"test").first
jQuey.data(div,"test").last

13.移除存储到某元素上的值

<div>value1beforecreation:<span></span></div>
<div>value1aftercreation:<span></span></div>
<div>value1afterremoval:<span></span></div>
<div>value2afterremoval:<span></span></div>
vardiv=$("div")[0];
//存储值
jQuery.data(div,"test1","VALUE-1");
//移除值
jQuery.removeData(div,"test1");

14.绑定函数的上下文

jQuery.proxy(function,context)返回一个新的function函数,上下文是context。

$(document).ready(function(){
varobjPerson={
name:"JohnDoe",
age:32,
test:function(){
$("p").after("Name:"+this.name+"<br>Age:"+this.age);
}
};
$("button").click($.proxy(objPerson,"test"));
});

以上,点击按钮,执行的是test方法,不过test方法的上下文做了设置。

15.解析JSON

jQuery.parseJSON(json)第一个参数json的类型是字符串。

varobj=jQuery.parseJSON("{"name":"John"}");
alert(obj.name==="John");

16.表达式求值

有时候,希望一段代码在全局上下文中执行,可以使用jQuery.globalEval(code)。code的类型是字符串。

functiontest(){
jQuery.globalEval("varnewVar=true;")
}
test();

17.动态加载脚本

$(selector).getScript(url,success(response,status))用来动态加载js文件,第一个参数是js的文件路径,第二个参数可选,表示获取js文件成功的回调。

$.getScript("ajax/test.js",function(data,textStatus,jqxhr){
console.log(data);//Datareturned
console.log(textStatus);//Success
console.log(jqxhr.status);//200
console.log("Loadwasperformed.");
});

相信本文所述对大家的jQuery程序设计有一定的借鉴价值。