[jQuery教程]jQuery 工具类函数(二十四)
本章先介绍浏览器检测函数,然后,介绍 jQuery 各类测试类型函数的使用方法,同时,还介绍了字符串、URL 操作函数的使用技巧,最后,介绍了使用$.extend()方法扩展工具函数和 Object 对象的方法
获取浏览器的名称与版本信息
在 jQuery 中,通过$.browser对象可以获取浏览器的名称和版本信息,如$.browser.chrome为 true,表示当前为 Chrome 浏览器,$.browser.mozilla为 true,表示当前为火狐浏览器,还可以通过$.browser.version方式获取浏览器版本信息。
示例代码:
$(function () { var strTmp = "您的浏览器名称是:"; if ($.browser.chrome) { //谷歌浏览器 strTmp += "Chrome"; } if ($.browser.mozilla) { //火狐相关浏览器 strTmp += "Mozilla FireFox"; } strTmp += "
版本号是:" //获取版本号 +$.browser.version; $(".content").html(strTmp); });
检测浏览器是否属于 W3C 盒子模型
浏览器的盒子模型分为两类,一类为标准的 w3c 盒子模型,另一类为 IE 盒子模型,两者区别为在 Width 和 Height 这两个属性值中是否包含 padding 和 border 的值,w3c 盒子模型不包含,IE 盒子模型则包含,而在 jQuery 中,可以通过$.support.boxModel对象返回的值,检测浏览器是否属于标准的 w3c 盒子模型。
例如,根据页面的特征,并通过$.support.boxModel 属性的返回值,显示当前浏览器是否属于标准的 w3c 盒子模型,如下代码所示:
$(function () { var strTmp = "您打开的页面是:"; if ($.support.boxModel) { //是 W3C 盒子模型 strTmp += "W3C 盒子模型"; } else { //是 IE 盒子模型 strTmp += "IE 盒子模型"; } $(".content").html(strTmp); });
检测对象是否为空
在 jQuery 中,可以调用名为$.isEmptyObject的工具函数,检测一个对象的内容是否为空,如果为空,则该函数返回 true,否则,返回 false 值,调用格式如下:
$.isEmptyObject(obj);
其中,参数 obj 表示需要检测的对象名称。
例如,通过$.isEmptyObject()函数,检测某个指定的对象是否为空,并将结果显示在页面中,如下代码所示:
$(function () { var obj = { "姓名": "土豪一族" }; var strTmp = "您定义了一个:"; if ($.isEmptyObiect(obj)) { //检测是否为空 strTmp += "空对象"; } else { strTmp += "非空对象"; } $(".content").html(strTmp); });
检测对象是否为原始对象
调用名为$.isPlainObject的工具函数,能检测对象是否为通过”{}”或”new Object()”关键字创建的原始对象,如果是,返回 true,否则,返回 false 值,调用格式为:
$.isPlainObject (obj);
其中,参数 obj 表示需要检测的对象名称。
例如,通过$.isPlainObject()函数,检测某个指定的对象是否为原始,并将结果显示在页面中,如下代码所示:
$(function () { var obj_a = {}; var obj_b = new Obiect(); var strTmp = "您定义了多个:"; if($.isPlainObject(obj_a) && $.isPlainObject(obj_b)){ //检测是否为原始对象 strTmp += "原始对象"; }else{ strTpm += "非原始对象"; } $(".content").html(strTmp); });
检测两个节点的包含关系
调用名为$.contains 的工具函数,能检测在一个 DOM 节点中是否包含另外一个 DOM 节点,如果包含,返回 true,否则,返回 false 值,调用格式为:
$.contains (container, contained);
参数 container 表示一个 DOM 对象节点元素,用于包含其他节点的容器,contained 是另一个 DOM 对象节点元素,用于被其他容器所包含。
例如,通过$.contains()函数,检测两个节点对象间是否存在包含关系,并将检测的结果显示在页面中,如下代码所示:
$(function () { var node_a = document.body.firstChild; var node_b = document.body; var strTmp = "对象 node_a"; if ($.contains(node_a,node_b)) { //检测是否包含节点 strTmp += " 包含 "; } else { strTmp += " 不包含 "; } strTmp += "对象 node_b"; $(".content").html(strTmp); });
字符串操作函数
调用名为$.trim 的工具函数,能删除字符串中左右两边的空格符,但该函数不能删除字符串中间的空格,调用格式为:
$.trim (str);
参数 str 表示需要删除左右两边空格符的字符串。
例如,通过$.trim()函数,除掉一个两边均有空格符的字符串,并将其执行前后的字符长度都显示在页面中,如下代码所示:
$(function () { $("#btnShow").bind("click", function () { $(".tip").html(""); var strTmp = "内容:"; var strOld = $("#txtName").val(); var strNew =$.trim(strOld); strTmp += strOld; strTmp += "
除掉空格符前的长度:" strTmp += strOld.length; strTmp += "
除掉空格符后的长度:" strTmp += strNew.length; $(".tip").show().append(strTmp); }); });
URL 操作函数
调用名为$. param 的工具函数,能使对象或数组按照 key/value 格式进行序列化编码,该编码后的值常用于向服务端发送 URL 请求,调用格式为:
$.param (obj);
参数 obj 表示需要进行序列化的对象,该对象也可以是一个数组,整个函数返回一个经过序列化编码后的字符串。
例如,通过$.param()函数,对指定的对象进行序列化编码,使其成为可执行传值的 URL 地址,并将该地址显示在页面中,如下代码所示:
$(function () { //基本信息对象 var objInfo = new Object(); objInfo.name = "白富美"; objInfo.sex = 1; //序列化对象 var objNewInfo =$.param(objInfo); //显示序列化后的对象 var strTmp = "对象 白富美 序列化后:
"; strTmp += objNewInfo; //显示在页面中 $(".tip").show().append(strTmp); });
使用$.extend()扩展工具函数
调用名为$. extend 的工具函数,可以对原有的工具函数进行扩展,自定义类级别的 jQuery 插件,调用格式为:
$.extend ({options});
参数 options 表示自定义插件的函数内容。
例如,调用$.extend()函数,自定义一个用于返回两个数中最大值的插件,并在页面中将插件返回的最大值显示在页面中,如下代码所示:
/*------------------------------------------------------------/ 功能:返回两个数中最小值 参数:数字 p1,p2 返回:最小值的一个数 示例:$.MinNum(1,2); /------------------------------------------------------------*/ (function ($) { $.extend({ "MinNum": function (p1, p2) { return (p1 > p2) ? p2 : p1; } }); })(jQuery); $(function () { $("#btnShow").bind("click", function () { $(".tip").html(""); var strTmp = "17 与 18 中最小的数是:"; strTmp +=$.MinNum(17, 18); //显示在页面中 $(".tip").show().append(strTmp); }); });
使用$.extend()扩展 Object 对象
除使用$.extend 扩展工具函数外,还可以扩展原有的 Object 对象,在扩展对象时,两个对象将进行合并,当存在相同属性名时,后者将覆盖前者,调用格式为:
$.extend (obj1,obj2,…objN);
参数 obj1 至 objN 表示需要合并的各个原有对象。
例如,调用$.extend()函数对两个已有的对象进行合并,并将合并后的新对象元素内容显示在页面中,如下代码所示:
$(function () { var objInfo = { name: "" }; var objMess = { name: "白富美,", title: "欢迎与我联系!" }; var objNewInfo =$.extend(objInfo,objMess); var strTmp = "对象 白富美 合并后:
"; strTmp += objNewInfo.name + objInfo.title; //显示在页面中 $(".tip").show().append(strTmp); });
结果:
<strong>对象 白富美 合并后: </strong>白富美,欢迎与我联系!
当两个对象通过$.extend()函数扩展合并后,返回一个包含两个对象中全部属性元素的新对象,相同名称的“name”属性,前者被后者覆盖。
好了,学了这么多是时候检验一下我们学习的情况了
编程挑战
自定义一个 jquery 插件,要求:在列表<ul>元素中,鼠标在列表项<li>元素移动时,可以自定义其获取焦点(focus)时的背景颜色,即设置表项<li>元素选中时的背景色.
完整代码如下:
<!DOCTYPE html> <html> <head> <title>自定义 focusColor 插件</title> <script type="text/javascript" src="jquery-1.8.2.min.js"></script> <style> .fl{ background:purple; padding:5px; color:white; } .content ul li span{ padding-right:20px; } .content ul li{ background:aquamarine; } </style> </head> <body> <div id="divtest"> <div class="title"> <span class="fl">自定义 focusColor 插件</span> </div> <div class="content"> <ul id="test"> <li><span>橘子</span><span>水果</span></li> <li><span>芹菜</span><span>蔬菜</span></li> <li><span>香蕉</span><span>水果</span></li> </ul> </div> </div> <script type = "text/javascript"> $(function(){ $("#test li").each(function(index){ $(this).focusColor("gray"); }); }); (function ($) { $.fn.extend({ "focusColor": function (newColor) { var oldColor = $(this).css('background-color'); $(this).hover( function(){ $(this).css('background-color',newColor) }, function(){ $(this).css('background-color',oldColor) } ); return $(this); } }); })(jQuery); </script> </body> </html>
码云笔记 » [jQuery教程]jQuery 工具类函数(二十四)