jQuery实用函数用法总结

1.修剪字符串

?


1

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

2.遍历集合

可能这样写:

?


1

2

3

4

var anArray = [‘one‘,‘two‘];

for(var n = 0; n < anArray.length; n++){

  

}

还有可能这样写:

?


1

2

3

4

var anObject = {one: 1, two: 2};

for(var p in anObject){

  

}

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

?


1

2

3

4

5

6

7

8

var anArray = [‘one‘,‘two‘];

$.each(anArray, funtion(n, value){

  

})

var anObject = {one: 1, two: 2};

$.each(anObjct, function(name,value){

  

})

3.筛选数组

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

?


1

2

3

4

5

6

7

8

9

10

11

grep: function(elems, callback, inv){

  var ret = [], retVal;

  inv = !!inv;

  for(var i = 0; length = elems.length; i < length; i++){

    retVal = !!callback(elems[i],i)

    if(inv !== retVal){

      ret.push(elems[i]);

    }

  }

  return ret;

}

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

举例1:int类型数组

?


1

2

3

4

5

var arr = [1, 2, 3, 4, 5, 6];

arr = $.grep(arr, function(val, index){

  return val > 3;

})

console.log(arr);//结果是:4 5 6

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

?


1

2

3

4

5

var arr = [1, 2, 3, 4, 5, 6];

arr = $.grep(arr, function(val, index){

  return val > 3;

}, true)

console.log(arr);//结果是:1 2 3

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

举例2:object类型数组

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

var arr = [

  {

    first: "Jeffrey",

    last: ‘Way‘

  },{

    first: ‘Allison‘,

    last: ‘Way‘

  },{

    first: ‘John‘,

    last: ‘Doe‘

  },{

    first: ‘Thomas‘,

    last: ‘Way‘

  };

  arr = $.grep(arr, function(obj, index){

    return obj.last === ‘Way‘;

  });

  console.log(arr);

];

4.转换数组

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

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

?


1

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

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

?


1

2

3

4

5

var strings = [‘1‘, ‘2‘, ‘3‘,‘4‘,‘S‘,‘6‘];

var values = $.map(strings, function(value){

  var result = new Number(value);

  return isNaN(result) ? null : result;

})

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

?


1

var chars = $.map([‘this‘,‘that‘], function(value){return value.split(‘ ‘)});

5.返回数组元素的索引

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

?


1

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

6.将对象转换成数组

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

?


1

2

3

4

5

6

7

8

9

10

<div>First</div>

<div>Second</div>

<div>Third</div>

<div>Fourth</div>

<script>

  var elems = document.getElementsByTagName("div");

  var arr = jQuery.makeArray(elems);

  arr.reverse();

  $(arr).appendTo(document.body);

</script>

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

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

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

<div>There are 6 divs in this document.</div>

<div></div>

<div class="dup"></div>

<div class="dup"></div>

<div class="dup"></div>

<div></div>

//把到所有div,get方法转换成javascript数组,总共6个div

var divs = $("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)把第二个数组合并到第一个数组中,并返回第一个数组。

?


1

2

3

4

var a1 = [1, 2];

var a2 = [2, 3];

$.merge(a1, a2);

console.log(a1);//[1, 2, 2, 3]

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

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

?


1

2

3

4

5

6

7

8

9

10

$(document).ready(function(){

 personObj=new Object();

 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是通过{}或new Object()创建的对象,则返回true
$.isXMLDoc(node) 如果node是XML文档或者是XML文档中的节点,则返回true

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

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

?


1

2

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

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

12.把值存储到某元素上

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

?


1

2

3

4

5

6

7

8

9

10

//得到一个div的javascript对象

var div = $("div")[0];

//把键值存储到div上

jQuery.data(div, "test",{

  first: 16,

  last: ‘pizza‘

})

//根据键读出值

jQuery.data(div, "test").first

jQuey.data(div, "test").last

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

?


1

2

3

4

5

6

7

8

9

<div>value1 before creation: <span></span></div>

<div>value1 after creation: <span></span></div>

<div>value1 after removal: <span></span></div>

<div>value2 after removal: <span></span></div>

var div = $( "div" )[ 0 ];

//存储值

jQuery.data( div, "test1", "VALUE-1" );

//移除值

jQuery.removeData( div, "test1" );

时间: 2024-09-30 05:55:05

jQuery实用函数用法总结的相关文章

jQuery复习—DOM无关的jQuery实用函数

DOM无关的jQuery实用函数 一.实用函数的定义 定义在jQuery/$命名空间下不操作包装集的函数.一般来说这些使用函数要么操作除DOM元素以外的JavaScript对象,要么执行一些与Dom操作无关的操作. 二.操作JavaScript对象和集合 1.修建字符串  $.trim(value) 定义:删除传入的字符串开头和结尾处的空白字符,并返回修改后的结果 参数:value需要修改的字符串 返回值:修改后的字符串 $.trim($('#someFiled').val()); 2.遍历属性

jQuery is()函数用法3例

这篇文章主要介绍了jQuery is()函数用法3例,jQuery的is()函数其实是非常有用的,能不能用好直接决定你的代码是否高效,需要的朋友可以参考下. jQuery提供了is()方法可以很方便的判断元素是否可见,是否隐藏,是否选中. 一.判断元素是否隐藏 如下html中的div元素是隐藏的: 代码如下: <!doctype html> <html> <head> <script src="http://ajax.microsoft.com/ajax

DOM无关的jQuery实用函数

实用函数:定义在jQuery/$命名空间下不操作包装集的函数,可以看做定义在$实例而不是window实例上的顶级函数.一般这些实用函数要么操作除DOM元素以外的对象,要么执行一些对象无关的操作. 公共用途的jQuery标志: $.fx.off:启用或禁用特效,不会废除已经在页面使用的特效,只是禁用了动画特效. $.support:所支持特征的详细信息 $.browser:公开浏览器的细节,jQuery 从 1.9 版开始,移除了 $.browser 和 $.browser.version , 取

【学亮IT手记】jQuery each()函数用法实例

1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <script src="https://cdn.bootcss.com/jquery/1.10.2/jquery.min.js"></script> 6 <script type="text/javascript"> 7 $(functi

Jquery css函数用法(判断标签是否拥有某属性)

判断一个层是否隐藏: $("#id").css("display")=="none"  ; 在所有匹配的元素中,设置一个样式属性的值: $("p").css("color","red"); 把一个"名/值对"对象设置为所有匹配元素的样式属性.这是一种在所有匹配的元素上设置大量样式属性的最佳方式 1    $("p").css({ color: &q

jQuery碎语(4) 实用函数

6.实用函数 ● 修剪字符串 $('#id').val($.trim($('#someid').val())) ● 遍历集合 可能这样写: var anArray = ['one','two']; for(var n = 0; n < anArray.length; n++){ } 还有可能这样写: var anObject = {one: 1, two: 2}; for(var p in anObject){ } 但有了$.each函数后,就可以这样写了: var anArray = ['on

jquery教程-Jquery 获取标签个数 size()函数用法

jquery教程-Jquery 获取标签个数 size()函数用法,size() 方法返回被 jQuery 选择器匹配的元素的数量. 语法 $(selector).size() jQuery 对象中元素的个数. 这个函数的返回值与 jQuery 对象的'length' 属性一致. 用途:可用于统计某个页面中某些项的数量.比如要统计语文成绩小于100的记录数,可以给小于100 的字段赋上<font class="xx">oo</font>.统计出此标签的数量即得结

jQuery.trim() 函数及trim()用法详解

先要明确,原生js里不含有trim()方法.如果你觉得有,那一定是记成Java里了. 解决方法如下所示: 1.使用JQuery提供的$.trim([要操作的对象]); 2.自己封装一个方法进行空白字符的截取. 这里只用第一种方法,jQuery自带的trim jQuery.trim()函数用于去除字符串两端的空白字符.该函数可以去除字符串开始和末尾两端的空白字符(直到遇到第一个非空白字符串为止).它会清除包括换行符.空格.制表符等常见的空白字符. 该函数属于全局的jQuery对象. 语法 jQue

jQuery - 01. jQuery特点、如何使用jQuery、jQuery入口函数、jQuery和DOM对象的区别、jQuery选择器、

this指的是原生js的DOM对象 .css(""):只写一个值是取值,写俩值是赋值 window.onload   ===   $(document).ready(); $(""):获取元素   标签名..类名.#id jQuery特点 链式编程 jq.shou(3000).html(内容) 相当于 jq.shou(3000) jq.gtml(内容) 隐式迭代 隐式实用for循环.迭代 如何使用jQuery 引包 一定要在使用之前 <script src =