亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

jQuery實用函數用法總結

2019-11-20 14:13:54
字體:
來源:轉載
供稿:網友

本文以實例的形式總結了jQuery的常見實用函數。分享給大家供大家參考之用。具體示例如下:

1.修剪字符串

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

2.遍歷集合

可能這樣寫:

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 = ['one','two'];$.each(anArray, funtion(n, value){  })var anObject = {one: 1, two: 2};$.each(anObjct, function(name,value){  })

3.篩選數組

使用$.grep()方法能篩選數組。先來看grep方法的定義:

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類型數組

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,結果怎樣呢?

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類型數組

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:

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

把字符串數組轉換成整型數字數組,判斷數組元素是否是數字:

var strings = ['1', '2', '3','4','S','6'];var values = $.map(strings, function(value){  var result = new Number(value);  return isNaN(result) ? null : result;})

把轉換后的數組合并到原先的數組中:

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

5.返回數組元素的索引

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

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

6.將對象轉換成數組

$.makeArray(object)將傳入類似數組的對象轉換成Javascript數組。

<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)返回由原始數組中不重復的元素組成的數組。

<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個divvar divs = $("div").get();//再把3個class名為dup的div合并到前面的6個divdivs = divs.concat($(".dup").get());alert(divs.length); //9個div//過濾去掉重復divs = jQuery.unqiue(divs);alert(divs.length);//6個div

8.合并2個數組

$.merge(array1, array2)把第二個數組合并到第一個數組中,并返回第一個數組。

var a1 = [1, 2];var a2 = [2, 3];$.merge(a1, a2);console.log(a1);//[1, 2, 2, 3]

9.把對象序列化成查詢字符串

$.param(params)把傳入的jquery對象或javascript對象轉換成字符串形式。

$(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)第二個參數是被包含

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

12.把值存儲到某元素上

$.data(element, key, value)第一個是javascript對象,第二、第三個是鍵值。

//得到一個div的javascript對象var div = $("div")[0];//把鍵值存儲到div上jQuery.data(div, "test",{  first: 16,  last: 'pizza'})//根據鍵讀出值jQuery.data(div, "test").firstjQuey.data(div, "test").last

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

<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" );

14.綁定函數的上下文

jQuery.proxy( function, context)返回一個新的function函數,上下文是context。

 $(document).ready(function(){ var objPerson = {  name: "John Doe",  age: 32,  test: function(){   $("p").after("Name: " + this.name + "<br> Age: " + this.age);  } }; $("button").click($.proxy(objPerson,"test"));});

以上,點擊按鈕,執行的是test方法,不過test方法的上下文做了設置。

15.解析JSON

jQuery.parseJSON( json )第一個參數json的類型是字符串。

var obj = jQuery.parseJSON( '{ "name": "John" }' );alert( obj.name === "John" );

16.表達式求值

有時候,希望一段代碼在全局上下文中執行,可以使用jQuery.globalEval( code )。code的類型是字符串。

function test() { jQuery.globalEval( "var newVar = true;" )}test();

17.動態加載腳本

$(selector).getScript(url,success(response,status))用來動態加載js文件,第一個參數是js的文件路徑,第二個參數可選,表示獲取js文件成功的回調。

$.getScript( "ajax/test.js", function( data, textStatus, jqxhr ) { console.log( data ); // Data returned console.log( textStatus ); // Success console.log( jqxhr.status ); // 200 console.log( "Load was performed." );});

相信本文所述對大家的jQuery程序設計有一定的借鑒價值。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美壮男野外gaytube| 成人免费淫片aa视频免费| 国产精品69久久| 国产噜噜噜噜噜久久久久久久久| 一本色道久久88精品综合| 欧美大片网站在线观看| 国产精品精品一区二区三区午夜版| 插插插亚洲综合网| 日韩精品亚洲视频| 久久成人av网站| 亚洲男子天堂网| 国产视频精品xxxx| 另类美女黄大片| 久久精品国产一区二区三区| 欧美精品精品精品精品免费| 欧美片一区二区三区| 自拍偷拍亚洲精品| 欧美高清在线播放| 午夜精品一区二区三区在线视频| 欧美重口另类videos人妖| 国产精彩精品视频| 久久精品视频在线观看| 国产这里只有精品| 福利精品视频在线| 欧美激情一级二级| 日本一区二区不卡| 亚洲第一视频网| 久久视频在线视频| 成人国产精品日本在线| 亚洲乱码一区二区| 亚洲精选一区二区| 操日韩av在线电影| 欧美老女人bb| 8090成年在线看片午夜| 精品在线欧美视频| 日本一区二区三区在线播放| 国产精品久久久久久久久久99| 综合国产在线视频| 日本道色综合久久影院| 亚洲日本欧美中文幕| 伊人久久久久久久久久久久久| 国产精品久久激情| 国产精品综合久久久| 久久久久久亚洲精品不卡| 91美女福利视频高清| 国产精品成人品| 欧美激情综合色| 国自产精品手机在线观看视频| 精品国产自在精品国产浪潮| 日韩av在线看| 夜夜嗨av色综合久久久综合网| 亚洲第一区中文99精品| 久久视频这里只有精品| 九九热r在线视频精品| 中文字幕精品av| 91久久精品久久国产性色也91| 456国产精品| 欧美视频在线观看免费网址| 一区二区成人精品| 亚洲毛片在线观看.| 992tv在线成人免费观看| 97精品一区二区视频在线观看| 九九精品视频在线| 欧美伦理91i| 国产va免费精品高清在线| 亚洲最新在线视频| 欧美怡红院视频一区二区三区| 国产伦精品免费视频| 国产精品劲爆视频| 韩国v欧美v日本v亚洲| 成人夜晚看av| 亚洲网站在线播放| 4438全国成人免费| 成人午夜小视频| 88国产精品欧美一区二区三区| 亚洲自拍偷拍在线| 久久影院资源网| 91综合免费在线| 日韩女优人人人人射在线视频| 国产香蕉精品视频一区二区三区| 色视频www在线播放国产成人| 国产一区二区成人| 亚洲国产成人久久综合| 精品久久久国产精品999| 精品成人在线视频| 国产精品免费看久久久香蕉| 久久久精品久久久久| 日韩国产欧美精品一区二区三区| 91a在线视频| 精品国产依人香蕉在线精品| 色综合天天综合网国产成人网| 久久夜精品va视频免费观看| 久久久久久97| 全球成人中文在线| 夜夜嗨av一区二区三区四区| 国产精品aaa| 国产日韩中文在线| 欧美日韩国产123| 国产精品嫩草影院久久久| 日韩美女av在线免费观看| 亚洲直播在线一区| 亚洲黄色在线观看| 中文字幕国产精品久久| 精品欧美国产一区二区三区| 午夜精品久久久久久99热| 亚洲成人久久一区| 伊人伊成久久人综合网站| 免费不卡欧美自拍视频| 日韩欧美在线免费| 大桥未久av一区二区三区| 精品无人国产偷自产在线| 日韩成人中文电影| 国内伊人久久久久久网站视频| 欧美成人精品三级在线观看| 日韩av电影手机在线观看| 91在线色戒在线| 亚洲国模精品一区| 日韩毛片中文字幕| 日韩成人xxxx| 国产成人av在线| 久久人人爽人人爽人人片av高请| 热久久视久久精品18亚洲精品| 精品少妇一区二区30p| 亚洲国产又黄又爽女人高潮的| 一本一本久久a久久精品综合小说| 国产福利精品在线| 日本免费在线精品| 日本午夜人人精品| 久久6免费高清热精品| 亚洲tv在线观看| 九九视频这里只有精品| 亚洲有声小说3d| 欧美精品电影免费在线观看| 国产精品日日摸夜夜添夜夜av| 久久精品欧美视频| 欧美国产日韩一区二区| 欧美极度另类性三渗透| 欧美日韩国产麻豆| 成人福利视频在线观看| 亚洲网址你懂得| 日韩国产欧美精品一区二区三区| 国产日韩欧美电影在线观看| 亚洲欧美国产精品va在线观看| 欧美巨乳美女视频| 欧美精品一区二区免费| 日韩电影免费观看在线观看| 久久97精品久久久久久久不卡| 欧美激情视频在线免费观看 欧美视频免费一| 国产69精品久久久久99| 亚洲欧洲日产国产网站| 久99九色视频在线观看| 久久综合九色九九| 91精品视频在线播放| 国产成人精品视频在线观看| y97精品国产97久久久久久| 亚洲91精品在线| 视频在线一区二区| 一本久久综合亚洲鲁鲁| 亚洲自拍av在线| 日韩av综合网| 国产精品免费看久久久香蕉| 日本精品久久久久影院| 欧美综合在线第二页| 成人国产在线激情|