- 浏览: 433212 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
springaop_springmvc:
apache lucene开源框架demo使用实例教程源代码下 ...
Java搜索工具——Lucene实例总结(一) -
chengang292214:
总结的不错
Web开发中的路径问题 -
liuyuanhui0301:
aka~
Java 归并排序(基于数组) -
IT人_:
不错
远程连接MySQL,防火墙阻止访问,解决办法 -
zhuchao_ko:
借鉴。
JNDI访问LDAP
工具函数的一般格式如下:$.函数名()或jQuery.函数名()
1. 浏览器检测
- 浏览器名称或版本信息
可通过$.browser对象获取浏览器信息
属性:
webkit 为true表示是webkit相关的浏览器
mozilla 为true表示是mozilla相关的浏览器
safari 为true表示safari相关的浏览器
opera 为true表示opera相关的浏览器
msic 为true表示IE浏览器
version 获取浏览器版本
例子:
if ($.browser.msie) { //IE浏览器 strTmp = "IE"; } if ($.browser.mozilla) { //火狐相关浏览器 strTmp = "Mozilla FireFox"; } trTmp = " 版本号是:"+ $.browser.version; //获取版本号
在Mozilla 浏览器中,$.browser.version显示的是内核版本,不是浏览器版本
- 盒子模型
盒子模型是CSS术语,用来描述页面设置中的各种属性,如内容(content),填充(padding),边框(border),边界(margin)
有两类盒子模型:W3C模型和IE盒子模型
W3C模型的属性height与Width取值不包含padding和border,仅仅指内容(content)的height与width
IE盒子模型的height与width属性值包含padding和border
$.support.boxModel返回一个布尔值,为true表示是W3C盒子模型,否则表示IE盒子模型
if ($.support.boxModel) { //是W3C盒子模型 strTmp += "W3C盒子模型"; }
2. 数组和对象操作
- 遍历数组
$.each()可以实现页面元素的遍历和指定数组的遍历
$.each(obj,fn(para1,para2)) obj表示要遍历的数组或对象
例子:
var arrStu = { "张三:": "60", "李四:": "70", "王二:": "80" } var strContent = "<li class='title'>姓名:分数</li>"; $.each(arrStu, function(Name, Value) { strContent += "<li>" + Name + Value + "</li>"; })
- 遍历对象
$.each($.ajaxSettings, function(Property, Value) { strContent += "<li>" + Property + ":" + Value + "</li>"; })
- 数据筛选
$.grep(array,function(elementOfArray,indexInArray),[event]) 根据条件筛选元素
array为要筛选的数组,elementOfArray为数组中的元素值,indexInArray为元素在数组中的序号,[event]为布尔值,表示是否根据fn的规则取反向结果。默认为false,表示不取反。
例子:查询素组中元素值大于5且序号小于8的元素
$(function() { var strTmp = "筛选前数据:"; var arrNum = [2, 8, 3, 7, 4, 9, 3, 10, 9, 7, 21]; var arrGet = $.grep(arrNum, function(ele, index) { return ele > 5 && index < 8 //元素值大于5且序号小于8 },【true】) strTmp += arrNum.join(); strTmp += "<br/><br>筛选后数据:" strTmp += arrGet.join(); $("#divTip").append(strTmp); })
- 数据变更
$.map(array,callback(elementOfArray,indexInArray))按指定条件修改数组中的所选元素
例子:将数组中元素值大于5且序号小于8的元素都增加3
$(function() { var strTmp = "变更前数据:"; 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; //元素增加1 } }) strTmp += arrNum.join(); strTmp += "<br/><br>变更后数据:" strTmp += arrGet.join(); $("#divTip").append(strTmp); })
- 数据搜索
$.inArray(value,array) 在数组中搜索某个元素,相当于javaScript中indexOf()搜索字符串中的某个字符。在$.inArray()中,如果找到了指定的某个元素,则返回该元素在数组中的索引号,否则返回-1。value表示搜索对象,array表示搜索数组。
例子:
$(function() { var strTmp = "待搜索数据:"; var arrNum = [4, 21, 2, 12, 5]; var arrPos = $.inArray(2, arrNum); strTmp += arrNum.join(); strTmp += "<br/><br>搜索后结果:" strTmp += arrPos; $("#divTip").append(strTmp); })
3. 字符串操作
- $.trim(str)删除字符串str中左右两边的空格符
- Startwith
- Endwith
4. 测试操作
- $.isArray(obj) 检测obj是否是数组对象
- $.isFunction(obj)检测obj是否是一个函数
- $.isEmptyObject(obj)检测obj是否是一个空对象
例子:
$(function() { var obj0 = {}; var obj1 = { "name": "taoguorong" }; var strTmp = "obj0是否为空:" + $.isEmptyObject(obj0);//true strTmp += "<br><br>obj1是否为空:" + $.isEmptyObject(obj1);//false $("#divTip").append(strTmp); })
- $.isPlainObject(obj)检测obj是否是一个原始对象
$(function() { var obj0 = {}; var obj1 = new Object(); var obj2 = "null"; var strTmp = "obj0是否为原始对象:" + $.isPlainObject(obj0);//true strTmp += "<br><br>obj1是否为原始对象:" + $.isPlainObject(obj1);//true strTmp += "<br><br>obj2是否为原始对象:" + $.isPlainObject(obj2);//false $("#divTip").append(strTmp); })
- $.contains(container,contained)检测一个dom节点是否包含另一个dom节点。
$(function() { var node0 = document.documentElement;//代表文档根节点 var node1 = document.body;//文档根节点下的子节点 var strTmp = "对象node0是否包含对象node1:" strTmp += $.contains(node0, node1);//检测两者的包含关系 返回true $("#divTip").append(strTmp); })
5. URL操作
$.param(obj,[traditional]) 按照name/value的格式对数组或jQuery对象进行序列化,obj是要序列化的数组或对象。
$(function() { var arrInfo = { id: 101, name: "tao", sex: 0 }; //基本信息数组 //分数和汇总信息数组 var arrScore = { Score: { chinese: 90, maths: 100, english: 98 }, SunNum: { Score: 288, Num: 3 } }; //序列化各数组 var arrNewInfo = $.param(arrInfo); var arrNewScore = $.param(arrScore); var arrDecScore = decodeURIComponent($.param(arrScore)); //显示序列化后的数组 var strTmp = "<b>arrInfo数组序列化后</b>:"; strTmp += arrNewInfo; strTmp += "<br><br><b>arrScore数组序列化后</b>:"; strTmp += arrNewScore; strTmp += "<br><br><b>arrScore序列化解码后</b>:"; strTmp += arrDecScore; //显示在页面中 $("#divTip").append(strTmp); })
6. 自定义工具类函数
$.extend()函数,可以编写自定义的工具函数
/*------------------------------------------------------------/ 功能:返回两个数中最大值 参数:数字p1,p2 返回:最大值的一个数 示例:$.MaxNum(1,2); /------------------------------------------------------------*/ ; (function($) { $.extend({ "MaxNum": function(p1, p2) { return (p1 > p2) ? p1 : p2; } }); })(jQuery); /*------------------------------------------------------------/ 功能:返回两个数中最小值 参数:数字p1,p2 返回:最小值的一个数 示例:$.MinNum(1,2); /------------------------------------------------------------*/ ; (function($) { $.extend({ "MinNum": function(p1, p2) { return (p1 > p2) ? p2 : p1; } }); })(jQuery); $(function() { var strTmp = "5与6中最大的数是:"; strTmp += $.MaxNum(5, 6); strTmp += "<br><br>7与8中最小的数是:"; strTmp += $.MinNum(7, ; $("#divTip").append(strTmp); })
$.extend()另外一个强悍的功能,就是可以扩展已有的Object对象:$.extend(target, object1,object2,…) 其中target表示合并后的对象,object表示被合并对象。
例:
var objName={name:“张三”,sex:”男”}; var objInfo={name:”李四”,age:30}; var objLast=$.extent(objName,objInfo); 结果:objLast={name:”李四”,sex:”男”,age:”30”}
可以看出,$.extend()函数在合并对象时,相同的参数名称,后面对象会覆盖前面对象的参数值。
7. $.proxy()处理不同作用域对象事件
$.proxy(function,scope)
$.proxy(scope,name)
$.proxy()返回一个新的函数,这个函数始终保持特定的作用域。当一个事件函数被元素绑定时,其作用域原则上应指向该元素。参数scope为被事件函数设定的作用域对象
例子:
$(function() { var objMyInfo = { name: "陶国荣", //设置对象name属性 sex: "男", //设置对象sex属性 ShowEvent: function() { //设置执行的事件 $("#divShow").html("姓名:" + this.name + "<br><br>性别:" + this.sex); } } $("#Button1").bind("click", $.proxy(objMyInfo, "ShowEvent"));//通过proxy函数绑定设置的事件 })
$("#Button1").bind("click", $.proxy(objMyInfo, "ShowEvent"));与
$("#Button1").bind("click",objMyInfo.ShowEvent);的区别是,后者传递的this作用域与事件函数中的this的作用域不同,因此,无法访问事件函数中的name与sex属性。而前者指定作用域是objMyInfo,即,代表事件中this的作用域。前者等价于$("#Button1").bind("click", $.proxy(objMyInfo.ShowEvent, objMyInfo));
8. 正则表达式字符串类型检验
发表评论
-
How tomcat works
2011-10-30 10:01 10821. Tomcat 模型:connector--------- ... -
jQuery Cookie插件
2011-10-06 10:49 0back>> cookie插件可以很 ... -
jQuery form表单插件
2011-10-06 10:45 1015back>> http://www.cnbl ... -
jQuery验证插件
2011-10-06 10:40 1413back>> 使用示例: <!DOCTY ... -
jQuery性能优化
2011-10-06 10:28 1687back>> 1. 优化选择器的执行速度 ... -
ajax在jQuery中的应用
2011-10-06 09:50 1821back>> 1. 加载异步数据 ... -
jQuery动画与特效
2011-10-05 15:26 2221back>> 1. 显示与隐 ... -
jQuery事件
2011-10-05 15:08 2627back>> 1. 事件机制 ... -
Jquery Dom操作
2011-10-05 14:44 1633back>> 1. 元素属性操作 ... -
jQuery选择器
2011-10-05 09:04 2728back>> 1. 表格各 ... -
jQuery权威指南
2011-10-05 08:58 834jQuery权威指南 1. jQuery入门 2. ... -
Jquery入门
2011-09-28 14:41 11861. Jquery基本功能 * 访问和操作D ... -
comet pushlet
2011-08-12 17:49 21741.http://www.ibm.com/developerw ... -
Ajax开发
2011-07-25 21:50 15641. netbeans 中文版改成英文版 在NetBea ... -
CSS+DIV
2011-06-28 16:02 1130精通CSS+DIV网页样式与布局 曾顺 人民邮电出 ... -
jquery
2011-06-09 08:08 997http://www.css888.com/ jQuer ... -
jsp乱码解决大全(转自csdn一高手)
2011-03-04 17:01 2207好文章, ... -
Unicode 控制字符
2011-03-03 11:44 3182<li> : &am ... -
URL中汉字乱码问题
2011-02-26 12:01 1596返回 Oak>> 服务器 ... -
分 页
2011-02-23 18:27 855返回Oak>> 1. 几种不同的分 ...
相关推荐
在jQuery中,工具函数是指直接依附于jQuery对象,针对jQuery对象本身定义的方法,即全局性的,我们统称为工具函数,或Utilites函数 主要作用于:字符串、数组、对象 API:工具函数 调用格式: $.函数名()或jQuery.函数名...
jQuery工具函数是jQuery库中的一系列实用函数,它们提供了一种方便的方式来处理和操作JavaScript中的数据和DOM元素。本文将通过实例解析这些工具函数,帮助开发者更好地理解和运用它们。 首先,我们来看$.browser...
在`jQuery`中,`data()`函数分为两种形式:设置数据和获取数据。 ### 一、`data()`函数的基本使用 1. **获取数据**: 当我们使用`data()`函数不带参数时,它会返回与指定元素关联的数据对象。例如: ```...
本篇将基于提供的"jqueryAPI函数chm文档",深入探讨jQuery的核心API函数,帮助开发者更好地理解和运用这个强大的工具。 一、选择器(Selectors) jQuery的选择器功能强大,兼容CSS1至CSS3,同时还有自己的扩展选择...
8. **兼容性**:JQuery对浏览器的兼容性做得很好,可以很好地在不同的浏览器环境中运行,减少了开发者处理浏览器差异的工作。 9. **API文档**:JQuery的官方文档详尽且易懂,包含了所有方法、函数的使用示例,是...
`jQuery.extend`是jQuery库中一个非常实用且功能强大的函数,主要用于合并两个或多个对象的属性至一个新的对象中。这使得开发人员能够在编写插件或其他代码时方便地扩展jQuery的功能,或者简单地合并配置选项。 ###...
**jQuery实现的Ajax函数在ASP中的应用** Ajax(异步JavaScript和XML)技术允许网页在不重新加载整个页面的情况下与服务器交换数据并更新部分网页内容,显著提升了用户体验。jQuery库简化了JavaScript的Ajax操作,...
具体到使用步骤,用户需要先引入jQuery库(例如,引入jquery.1.10.2.min.js),然后调用该工具的JavaScript函数,传入待处理的中文字符串。工具会返回一个包含所有可能词组的数组,开发者可以根据需求进一步处理这些...
如果希望这两个动画按照顺序执行,可以在第一个animate函数的回调函数中加入第二个animate调用,如下: ```javascript $('#box').on('mouseover', function() { $('#box').animate({width: 600}, 500, function() ...
本文将深入探讨jQuery的基础函数,帮助初学者更好地理解和掌握这一工具。 1. **选择器(Selectors)** jQuery的核心在于其高效的选择器,它允许我们通过CSS样式选择HTML元素。例如,`$("#myID")`选择ID为`myID`的...
而jQuery.each(object, callback)函数则是一个通用的遍历工具,用于遍历对象和数组中的每个元素,并且在回调函数中以元素为上下文执行操作。jQuery.each()函数与jQuery对象的each()方法不同,后者是实例方法,但其...
5. **Ajax交互**:jQuery的`.ajax()`函数封装了XMLHttpRequest对象,使得异步数据获取变得简单,例如`$.get("url", function(data) {...})`用于发送GET请求,`$.post("url", data, function(response) {...})`则用于...
- 开发时,可利用未压缩的`jquery-1.12.4.js`进行调试,配合浏览器的开发者工具查看和理解代码执行过程。 - 生产环境中,推荐使用`jquery-1.12.4.min.js`以提高页面加载速度。 - 遇到具体问题时,查阅CHM文件中的API...
如果数组元素是对象,那么map函数的回调函数中的item将会是对象,而非基本类型数据,这可能不符合map函数的预期使用场景。 此外,文档中还介绍了一个自定义的遍历数组函数MyMap,它是直接使用原生JavaScript实现的...
在实际工作中,结合源码理解和工具辅助,可以更好地理解和定制jQuery的功能,实现更具个性化的前端交互。在压缩包"jquery_ch04"中,可能包含了一些示例代码或者进一步的解释,对于深入理解jQuery的功能函数非常有...
- jQuery动画:jQuery的animate()函数可以创建自定义动画,但可能需要配合CSS3来实现复杂的翻转效果。 - HTML结构:数字翻转通常需要创建两个具有相同数字但不同方向的副本,然后在动画过程中切换它们的可见性。 ...
jQuery的生态系统庞大,拥有无数的第三方插件和工具,这些可能包含在压缩包中: - **表单插件**:如validate.js用于表单验证,bootstrap-datepicker用于日期选择。 - **滑块/轮播插件**:如Bootstrap Carousel或...