属性列表说明
webkit webkit相关浏览器则返回true,否则返回false,如google,傲游。
mozilla mozilla相关浏览器则返回true,否则返回false,如火狐
safari safari相关浏览器则返回true,否则返回false,如safari
opera opera相关浏览器则返回true,否则返回false,如opera
msie msie相关浏览器则返回true,否则返回false,如ie,360,搜狗
version 返回对应浏览器的版本
$(function () { if ($.browser.msie) { alert("ie浏览器"); } if ($.browser.webkit) { alert("webkit浏览器"); } if ($.browser.mozilla) { alert("mozilla浏览器"); } if ($.browser.safari) { alert("safari浏览器"); } if ($.browser.opera) { alert("opera浏览器"); } alert($.browser.version); })
二、boxmodel
返回一个布尔值,如果是w3c盒子模型则返回true,否则返回false。
盒子模型分两类,一类是w3c盒子模型,一类是ie盒子模型。两者的根本区别在于w3c的盒子模型不包括padding与border,仅指content的height和width,而ie盒子模型包含padding与border。
<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title></title> <script src="jquery.1.8.3.js" type="text/javascript"></script> <script type="text/javascript"> $(function () { if ($.support.boxmodel) { alert("w3c盒子模型!"); } else { alert("ie盒子模型!"); } }) </script> </head> <body> </body> </html>
上面的例子弹出w3c盒子模型,如果删除掉顶部的两行,<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml">。则弹出的是ie盒子模型。
数组和对象的操作
三、$.each()
此工具函数不仅能够完成指定数组的遍历,还能够实现页面中元素的遍历。
语法:$.each(obj,fn(para1,para2))obj要遍历的数组或对象,fn为每个遍历元素执行的回调函数,para1表示数组的序号或对象的属性,para2表示数组的元素和对象的属性。
$(function () { var arr = [1, 2, 3, 4, 5]; $.each(arr, function (index, value) { document.write(index + ":"); document.write(value + "<br/>"); }); }) 输出: 0:1 1:2 2:3 3:4 4:5 $.each()遍历数组。
$(function () { var arr = { "张三": "23","李四": 22,"王五": "21" }; $.each(arr, function (index, value) { document.write(index + ":"); document.write(value + "<br/>"); }); }) 输出:张三:23 李四:22 王五:21
元素遍历
<head> <title></title> <script src="jquery.1.8.3.js" type="text/javascript"></script> <script type="text/javascript"> $(function () { $("p").each(function () { $(this).css("background-color", "red"); }); //一下三行代码与以上三行效果一样 //$.each($("p"), function () { // $(this).css("background-color", "red"); //}) }) </script> </head> <body> <p>我是第一个p</p> <p>我是第二个p</p> <p>我是第三个p</p> <p>我是第四个p</p> <p>我是第五个p</p> </body> </html>
四、$.grep()
筛选符合条件的元素,返回一个新数组
语法:$.grep(arrar,fn(value,index));要注意下回调函数的参数的顺序,第一个是值,第二个是索引。
$.grep(arrar,fn(value,index),[bool]);第三个参数表示是否取反,true表示取反,false表示不取反。
$(function () { var arr = [2, 5, 34, 22, 8]; var arr1 = $.grep(arr, function(value, index) { return index <= 2 && value < 10; }) document.write(arr1.join());//输出2,5 })
六、$.map()
改变函数内的数据,接受一个数组或类数组对象作为参数
$(function () { var arr = [2, 5, 34, 22, 8]; var arr1 = $.map(arr, function (value, index) { if (value > 5 && index < 3) { return value - 10; } }) document.write(arr.join() + "<br/>");//2,5,34,22,8可以看到原数组不改变 document.write(arr1.join()); //24新数组只获得了操作之后的结果 })
七、$.inarray()
如果数组中存在被搜索元素,则返回被搜索元素的索引
$(function () { var arr = [1, 2, 3, 4, 5]; alert($.inarray(4,arr));//弹出 3 })
八、$.trim()
去除字符串两边的空格
$(function () { var str = " 你在他乡还好吗? "; document.write("11" + str + "11" + "<br/>");//输出 11 你在他乡还好吗? 11 document.write("11" + $.trim(str) + "11"); //输出 11你在他乡还好吗?11//加个11是为了看清楚差别。 })
九、测试操作
$.isarray(obj)检测参数是否是数组
$.isfunction(obj) 检测参数是否是一个函数
$.isemptyobject(obj)检测参数是否是一个空对象
$.isplainobject(obj) 检测参数是否是一个纯粹对象,即对象是否通过{}或new object()关键字创建。
$.contains(container,contained)检测一个dom节点是否包含另一个dom节点。是则返回true否则表示false。注意参数是dom对象并非jquery对象。
$(function () { var arr = [1, 2, 3, 2, 1]; document.write(jquery.isarray(arr));//返回true var str = "123"; document.write(jquery.isarray(str));//返回false }) $(function () { var f = fun1; alert($.isfunction(fun1));//返回true }) function fun1() { } $(function () { var obj1 = {}; var obj2 = { name: "张飞" }; alert($.isemptyobject(obj1));//返回trueobj1是空对象 alert($.isemptyobject(obj2));//返回false obj2不是空对象 }) $(function () { var obj1 = {}; var obj2 = { name: "张飞" }; var obj3 = new object(); var obj4 = null; alert($.isplainobject(obj1));//true通过{}创建 alert($.isplainobject(obj2));//true通过{}创建 alert($.isplainobject(obj3));//true通过new object()创建 alert($.isplainobject(obj4));//flase不是通过{}或new object()创建 }) $(function () { alert($.contains($("#div1")[0],$("#p1")[0]));//返回true,注意参数是dom对象,并非jquery对象 })
十、$.param()
序列化成url字符串
$.param(obj,[bool]);第二个参数为可选参数,表示是否浅层序列化
$(function () { var man = { name: "张飞", age: 23 }; var str = $.param(man); document.write(str);//name=%e5%bc%a0%e9%a3%9e&age=23 var str1 = decodeuri(str); document.write("<br>" + str1);//name=张飞&age=23 })
十一、$.makearray()
将数组或类数组对象的属性复制到一个新的数组(真的是数组)中,并返回该新数组。
var arr = [1,3,5,7,9]; $(function () { var arr1 = $.makearray(arr); document.write(arr1.join());//输出 1,3,5,7,9 })
十二、$.merge()
该函数接受两个数组或类数组对象,将第二个参数附加到第一个参数上面,返回第一个参数,第一个数组会修改,第二个不会。
var arr1 = [1, 3, 5, 7, 9]; var arr2 = [2, 4, 6, 8, 10]; $(function () { var arr3 = $.merge(arr1, arr2); document.write(arr1.join() + "<br/>"); //1,3,5,7,9,2,4,6,8,10 document.write(arr2.join() + "<br/>"); //2,4,6,8,10 document.write(arr3.join() + "<br/>"); //1,3,5,7,9,2,4,6,8,10 })
十三、$.parsejson()
该函数会解析json格式的字符串,并返回解析结果(对象)。 类似于json.parse(),注意:jquery只定义了json解析函数,并没有定义序列化函数。
var man = { name: "张三", age: 23 }; var str = json.stringify(man); document.write(str + "<br/>"); //{"name":"张三","age":23} var man1 = $.parsejson(str); document.write(man1.name + man1.age); //张三23
十四、$.proxy()
类似于function对象的bind()方法,接受函数作为第一个参数,对象作为第二个参数,并返回一个新函数,该函数会作为第二个参数对象的方法调用。
$(function () { var obj = { name: "john", test: function () { alert(this.name);//当id为test的按钮点击时,弹出姓名 $("#test").unbind("click", obj.test);//并取消事件绑定(下次再点击不会弹出姓名) } }; $("#test").click(jquery.proxy(obj, "test"));//绑定object对象里面的方法test })
十五、$.unique(array)
删除元素数组中的重复元素
$(function () { var arr = [1, 2, 3, 2, 1]; jquery.unique(arr); alert(arr.join());//返回3,2,1 })
十六、$.extend()
合并对象中的元素
$(function(){ var result=$.extend({},{name:"tom",age:21}, {name:"jerry",sex:"boy"}); alert(result.name); //输出 jerry 后面的会覆盖前面的,result始终只是一个对象 })
省略dest参数,extend方法原型中的dest参数是可以省略的,如果省略了,则该方法就只能有一个src参数,而且是将该src合并到调用extend方法的对象中去。
要特别注意的一点是:后面的值会覆盖前面同名的值。
$(function(){ $.extend({ hello:function(){alert('hello');}//该方法只有一个参数,意味着将hello方法合并到jquery全局对象中去 }); $.hello(); //弹出 hello })
命名空间示例:
$(function(){ $.extend({net:{}}); //扩展一个命名空间 $.extend($.net,{ hello:function(){alert('hello');} //将hello方法绑定到命名空间net里去 }) $.net.hello(); //通过net命名空间调用方法 })
拷贝方法原型:
extend(boolean,dest,src1,src2,src3...)
其中第一个参数boolean表示是否进行深层拷贝。
$(function(){ var result=$.extend( true, {}, { name: "john", location: {city: "boston",country:"usa"} }, { last: "resig", location: {state: "ma",country:"china"} } ); alert(result.location.state); //输出 ma //result={name:"john",last:"resig", location:{city:"boston",state:"ma",county:"china"}} var result=$.extend( false, {}, { name: "john", location: {city: "boston",country:"usa"} }, { last: "resig", location: {state: "ma",country:"china"} } ); alert(result.location.city); //输出 undefined //result={name:"john",last:"resig",location:{state:"ma",county:"china"}} 注意没有city,只是合并了location,location里面的属性不管 })