在jQuery中,工具函数是指直接依附于jQuery对象,针对jQuery对象本身定义的方法,即全局性的函数,统称工具函数,或Utilities函数。
采用如下的格式进行调用:
$.函数名() 或 jQuery.函数()
根据工具函数处理对象的不同,可以将其分为下列几大类别:
在jQuery中,可以通过访问$.browser对象的属性获取浏览器的信息。$.browser对象即jQuery.browser对象,用于处理与浏览器相关的事务,该对象的属性如下:
属性名称 | 说明 |
webkit | 如果是webkit相关的浏览器,则为true |
mozilla | 如果是mozilla相关的浏览器,则为true |
safari | 如果是safari浏览器,则为true |
opera | 如果是opera浏览器,则为true |
msie | 如果是ie浏览器,则是true |
version | 获取浏览器的版本号 |
通过 jQuery.support.boxModel对象返回的属性值,确定页面是否是标准的W3C盒子模型。该方法返回一个布尔值,如果是true表示是W3C盒子模型。
$.support.boxModel
使用$.each()工具函数,其调用的语法格式如下:
$.each(obj, fn(para1, para2))
参数 obj 表示要遍历的数组或对象, fn 为每个遍历元素执行的回调函数,该函数包含2个参数, para1 表示数组的序号或对象的属性, para2 表示数组的元素或对象的属性的值
例如:
var arrStu = {"1":"2", "3":"4"}; $.each(arrStu, function(name, value){ ... ... // name: 1,3 value: 2 4 })
遍历对象,获取对象的属性和值。
使用工具函数jQuery.grep(),可以很方便的筛选数组中的任何元素,该函数的调用语法格式如下:
$.grep(array, function(elementOfArray, indexInArray), [invert])
参数array表示要筛选的数组,回调函数fn中可以设置两个参数,其中elementOfArray为数组中的元素,indexInArray为元素在数组中的序列号。另外,可选项[invert]为布尔值,表示是否根据fn的规则取反向结果,默认值为false,表示不取反。
例如:
var arrNum = [2, 8, 3, 7, 4, 9, 3, 10, 9, 7, 21]; var arrGet = $.each(arrNum, function(ele, index){ return ele > 5 && index < 8; // 元素值大于5其序号小于8 })
要按指定条件修改数组中的所选元素,还需要调用另外一个工具函数$.map(),其调用的语法格式如下:
$.map(array, callback(elementOfArray, indexInArray))
参数array表示要变更的原数组,回调函数fn中可以设置两个参数,其中elementOfArray为数组中的元素,indexInArray为元素在数组中的序列号。
例如:
var arrNum = [2, 8, 3, 7, 4, 9, 3, 10, 9, 7, 21]; var arrGet = $.map(arrNum, function(ele, index){ if (ele > 5 && index < 8)// 元素值大于5其序号小于8 { return ele + 1; // 变更后数据 9, 8, 10, 11 } })
要在数组中所有某个元素,可以使用工具函数$.inArray(),在工具函数$.inArray()中,如果找到了指定的某个元素,则返回该元素在数组中的索引号,否则,返回-1,其调用格式如下:
$.inArray(value, array)
参数value表示要搜索的对象,array表示搜索对象的数组。
在jQuery中,如果要除掉字符中左右两边的空格符,可以使用工具函数$.trim()。该函数也是jQuery核心库中唯一一个针对字符串操作的工具函数,其调用语法格式如下:
$.trim(str)
参数str为需要删除左右两边空格符的字符串。
jQuery中测试工具函数:
函数名称 | 说明 | 支持版本 |
$.isArray(obj) | 返回一个布尔值,检测参数obj是否是一个数组对象,如果为true,则表示是 | 1.3以上 |
$.isFunction(obj) | 返回一个布尔值,检测参数obj是否是一个函数 | 1.2以上 |
$.isEmptyObject(obj) | 返回一个布尔值,检测参数obj是否是一个空对象 | 1.4以上 |
$.isPlainObject(obj) | 返回一个布尔值,检测参数obj是否是一个纯粹对象,即对象是否通过{}或new Object()关键字创建 | 1.4以上 |
$.contains(container,contained) | 返回一个布尔值,检测一个DOM节点是否包含另一个DOM节点 | 1.4以上 |
工具函数$.param(),通过该函数可以使数组或jQuery对象按照name / value的格式进行序列化,普通对象按照 key/value的格式进行序列化。工具函数$.param()调用的语法格式如下:
$.param(obj, [traditional])
参数obj表示需要进行序列化的对象,该对象可以是数组,jQuery元素,普通对象,可选参数[traditonal]表示是否使用普通的方式浅层序列化。该函数返回一个序列化后的字符串。
需要使用另外一个工具函数 $.extend(),通过该函数,可以定义自己的工具函数。
例如:
<script type="text/javascript"> ; (function($){ $.extend({ "MaxNum" : function(p1, p2){ return (p1 > p2) ? p1 : p2; } }); })(jQuery); ; (function($){ $.extend({ "MinNum" : function(p1, p2){ return (p1 > p2) ? p2 : p1; } }); })(jQuery); $(function(){ var v1 = $.MaxNum(5, 6); var v2 = $.MinNum(7, 8)l }) </script>
$.extend(target, object1, ... [objectN])
参数target表示合并后的独享,object为被合并的对象,即可以将一个或对个对象合并成一个对象,最后返回该对象。在$.extend()函数中,如果是合并对象,且存在相同参数的名称,那么,后面对象中的参数值将覆盖前面对象中的参数值。
例如:
var objName = {name : "zhangsan", sex: "nan"}; var objInfo = {name : "lisi", age : 30}; var objLast = $.extend(objName, objInfo); 返回的结果是: objLast = {name: "lisi", sex: "nan", age: 30};
$.proxy()函数返回一个新的函数,并且这个函数始终保持特定的作用域。
所谓的作用域,就是执行该函数对象的范围。当一个事件函数被元素绑定时,其作用域原则上应指向该元素,但有些事件函数的作用域,在被元素绑定时并不指向元素本身,而是指向另外一个对象。这时,为了使元素的绑定事件能正常执行,必须调用函数$.proxy()进行处理。经过处理后的事件函数,不仅可以被绑定的元素执行,而且还可以传递原先函数取消事件的绑定,该函数调用的语法格式为:
$.proxy(function, scope)
参数function为要改变作用域的事件函数,参数scope为被事件函数设置作用域的对象。即事件函数的作用域将设置到该对象中。
该函数还有另一种调用的方法,代码如下:
$.proxy(scope, name)
参数scope为被事件函数设定的作用域对象,参数name为将要设置作用域的函数名,并且该参数必须是scope作用域对象的一个属性。
例如:
var objMyInfo = { name : "zhangsan", sex: "male", ShowEvent : function(){ ... ... this.name + this.sex; } } $("#Button1").bind("click", $.proxy(objMyInfo.ShowEvent, objMyInfo)); 或者 $("#Button1").bind("click", $.proxy(objMyInfo, “ShowEvent”));
如果直接绑定 objMyInfo中的函数showEvent,则该函数中的this作用域与传递的this作用域不同,因此,无法访问事件函数中的name和sex属性。