>> $ele.load(url, data, callback); //帶data參數時爲POST請求,不然爲GET請求 // $('#testload').load('data.html', {"name": "peter"}, function(r){console.log(r);}); //POST 所有html添加到容器中 // $('#testload').load('data.html h1', {"name": "peter"}, function(r){console.log(r);});//POST 部分html添加到容器中 $('#testload').load('data.html h1', function(r){console.log(r);});//GET 部分html添加到容器中 >> $.get(url,data, callback); $.get('test.php', {name:'kk', age:'a little old'}, function(r){ console.log('get:' + r); $('#testget').html(r); }); >> $.post(url, data, callback); //和$.get()同樣,只是請求的方式不一樣 $.post('test2.php',{title:'tower', des:'it is very tall'}, function(r){ console.log('post:' + r); $('#testpost').html(r); }); >> $.getJSON(url, data, callback); //當url爲非同源的,則會用jsonp的方式工做 1. $.getJSON('test.js',{name: 'windy', age: 18}, function(json){ //json爲對象,通過JSON.parse() console.log(json); $('#testgetjson').html( JSON.stringify(json) ); }); //當url爲非同源的,則會用JSONP的方式請求 //$.getJSON(crossUrl, data, callback); JSONP的工做方式: 回調函數callback 複製給臨時全局函數jquery164509.., 臨時全局函數傳遞給php頁面, php頁面組裝函數調用表達式,而後做爲<script>的內容返回給script, 解析執行後,刪除臨時的<script>標籤 2. $.getJSON('http://localhost:800/jsonp.php?callback=?', {name:'windy', age:20}, jsonpback); function jsonpback(data){ $('#testjsonp').html('jsonp data:' + JSON.stringify(data) );} >> $.getScript(url, callback) $.getScript('sayhi.js', function(r){ //加載並執行腳本文件 console.log('getScript:' +r, +' script has been loaded and executed.'); sayhi('summer'); }); >>------------------------ $.ajax(options) --------------------------- // $.ajax(options) //底層實現, 以上$.get(), $.post(), $.getJSON(), $.getScript() 內部都是調用$.ajax()的
options = {
type: 'GET / POST / PUT /DELETE'; //請求的方式 默認爲GET, 如 PUT 和 DELETE 也能夠使用,但僅部分瀏覽器支持。
url: 'handler.php', //請求的地址 默認爲當前頁
async: true, //是否異步請求
php
//發送到服務器的數據
data: {name:'sindy', age:18}, //自動被轉換爲url參數形式(name=sindy&age=18), 也能夠直接爲字符串 'name=sidy&age=18'
//對ajax返回的原始數據進行預處理的函數
contentType: 'application/x-www-form-urlencoded', //內容的編碼類型 默認爲 application/x-www-form-urlencoded
processData: true, //(默認: true) 默認狀況下,發送的數據將被轉換爲對象(技術上講並不是字符串)
以配合默認內容類型 "application/x-www-form-urlencoded"。若是要發送 DOM 樹信息或其它不但願轉換的信息,請設置爲 false。
dataType: "xml / html /script / json / jsonp/ text", //預期服務器返回的數據類型
dataFilter: function(data, type){.. },// data: ajax返回的數據, type: 調用$.ajax(options)時,指定的options.dataType
timeout: 5000, //設置請求超時時間(毫秒) 此設置將覆蓋全局設置
beforeSend: function(xhr){
this; //指向options
},
complete: function(xhr, textStatus){//請求完成(不管成功或失敗)時的回調函數
this; //指向options
},
success: function(data, textStatus){
//data 多是xmlDoc, jsonObj, html, text等..
this; //指向options
},
error: function(xhr, textStatus, error){
this; //指向options
},css
global: true, //是否觸發全局的ajax事件 (ajaxStart, ajaxStop)
cache: false, //不從瀏覽器緩存加載請求信息
ifModified: true, //默認false, 是否僅在服務器數據改變時獲取新數據, 使用Http包 last-modified頭信息判斷
jsonpCallback:'mycallback', //在jsonp請求中,重寫url參數裏的callback部分的回調函數(http://example.com/test.php?name="cici"&callback=?), 變爲callback=myCallback
scriptCharset: 'utf-8', //只有當請求時dataType爲"jsonp"或"script",而且type是"GET"纔會用於強制修改charset。一般在本地和遠程的內容編碼不一樣時使用。
password: '123'; //用於響應Http訪問認證請求的密碼
username: 'yourname' //用於響應Http訪問認證請求的用戶名
}html
jsonpCallback參數示例:jquery
var mycallback;
var url = 'http://localhost:8015/user.php';
$.ajax({
url: url,
method: 'get',
data:null,
dataType:'jsonp',
jsonpCallback:'mycallback',
success:function(data, textStatus,xhr){
console.log(data, textStatus);
}
});ajax
>>-------------------- ajax事件 -----------------json
1. $ele.ajaxComplete(callback);跨域
$('#msg').ajaxComplete(function(event, xhr, ajaxOptions){數組
$(this).append('<li>請求完成</li>');promise
}瀏覽器
2. $ele.ajaxSuccess(callback);
3. $ele.ajaxError(callback);
4. $ele.ajaxSend(callback);
$('#msg').ajaxSend(function(event, xhr, ajaxOptions){
$(this).append('<li>開始請求: ' + ajaxOptions.url + '</li>');
}
5. $ele.ajaxStart(callback);
$('#loading').ajaxStart(function(){ $(this).show(); }
6. $ele.ajaxStop(callback);
$('#loading').ajaxStop(function(){ $(this).hide(); }
>>---------------- $.ajaxSetup(options) -------------
> $.ajaxSetup(options); //全局設置,設置ajaxOptions的默認值
$.ajaxSetup({
url:'handler.php',
type:'POST',
global:false
});
$.ajax({data:mydata});
> $form.serialize(); //把表單內的控件的name/value屬性序列化爲 url參數形式
$('form').serialize();
> $('form').serializeArray(); //把表單內控件的name/value屬性序列化爲對象數組,如[{name1:value1}, {name2:value2}]
其餘API
$.fn.map(function(index, ele))
$.fn.each(function(index, ele)) //迭代函數 return false 終止遍歷
$.map(arr, function(ele, i))
// 隱式迭代
$(window).resize() -> $(window).trigger('resize')
$('body').click({hi:'hello'}, function(e){ console.log(e.data, 'clicked..');});
$.holdReady(true);
$.getScript('myplugin.js', function(){ $.holdReady(false); });
// load事件,url關聯的元素: img, script, link, frames, iframes, window
$('form').bind('submit', false) => $('form').bind('submit', function(){ return false; }); //取消默認事件 和 事件冒泡
event.preventDefault(); event.stopPropagation(); event.stopImmediatePropagation();
$('a.disabled').on('click', false); //取消點擊a的默認行爲和事件冒泡
// trigger(), triggerHandler()觸發事件時,傳遞數據
$('body').bind('myevent', function(evt, extraParams){ console.log(extraParams); });
$('body').trigger('myevent', 'hello');
$('body').on('myevent', function(evt, var1, var2){ console.log(var1, var2); });
$('body').trigger('myevent', ['hi', 'idle']);
$ele.delegate(selector, eventType, [eventData], handler);
$ele.delegate(selector, events);
// 自定義事件,事件命名空間, 解除綁定
$('div.test').off('click', '**');//移除全部代理事件
$('form').on('click.validator', 'button', validate);
$('form').on('keypress.validator', 'input', validate);
$('form').off('.validator');
event.originalEvent
event.target //觸發事件的最深層元素
event.relatedTarget //mouseover mouseout
event.result //上一個事件處理函數的返回值
$('body').on('click', function(ev){ return 'good'; });
$('body').on('click', function(ev){ console.log(ev.result); });
event.which //按鍵對應的keyCode
// 避免在大文檔中,過多的在document/body上代理事件 由於冒泡的路徑比較長
// 建立事件
ev = $.Event('submit');
$form.trigger(ev);
ev.isDefaultPrevented();
event.target, event.currentTarget, this , (event.currentTarget==this)
// event.nameSpace
$('body').on('test.ns', function(ev){ console.log(ev.nameSpace);});
$('body').trigger('test.ns');
//動畫
$ele.hide([duration],[easing],[complete] ); //slow normal fast 300, 500
$ele.hide(options);
options = {
duration: 'normal',
easing: 'linear', //默認支持 swing or linear
queue: true, //是否將動畫放入隊列中
specialEasing: {},
step: function(){}, //每一個動畫屬性的每次變化
progress: function(){}, //每一步動畫完成後執行
complete: function(){},
done: function(){},
fail: function(){},
always: function(){}
}
$.fx.off = true; //關閉動畫效果 直接設置爲最終值
$ele.hide('normal'); //無動畫效果了
$ele.animate(properties, duration, easing, complete);
//數值型屬性 properties: width height margin padding left top scrollLeft scrollTop border-width font-size opacity
//相對值 +=10 -=4
$ele.animate({left: '+=200'}, 400).queue(function(){//效果加入隊列
$(this).toggleClass('red');
$(this).dequeue();//取出隊列下一個效果並執行
});
$.dequeue(ele,[queueName]); //隊列名queueName默認爲 fx
$ele.finish([queueName]);//結束正在進行的動畫,清除隊列,全部動畫的css屬性設置爲最終值
$ele.stop(true, true); //相似finish(), 結束當前動畫,當前動畫的css屬性設置爲最終值,清除隊列
$ele.stop(isClearQueue, isToTargetVal);
$.fx.interval; // 13 多少毫秒渲染1幀
$ele.queue([queueName]); //返回已執行的函數隊列數
$ele.queue([queueName], newqueue);
$ele.queue([queueName], callback);//將函數加入到動畫隊列中,callback中須要執行$ele.dequeue()來讓後續動畫繼續
$ele.queue(function(next){
//do sth..
next();//同 $ele.dequeue();
});
$.queue(ele,[queueName]);
$.queue(ele,[queueName],callback);
$ele.stop(clearqueue, jumpToEnd);
$ele.fadeIn(duration,[easing],[complete]);
$ele.fadeIn(options);
$ele.fadeOut(..);
$ele.fadeTo(duration, opacity, [easing], [complete]);
$ele.fadeToggle(duration, [easing], [complete]);
$ele.slideDown(...);
$ele.slideUp(...);
$ele.slideToggle(..);
$ele.load(url, data, callback);// dataType:'html'
$.get(url, data, callback, dataType);
$.post(url, data, callback, dataType);
$.getJSON(url, data, callback); //get post or jsonp , set dataType:'json'
$.getScript(url, callback); //加載並執行腳本文件, 添加 <script>標籤 並在onload時執行回調
$.ajaxSetup(options);
$ele.ajaxSuccess(function(event, xhr, settings){ .. });
$ele.ajaxError();
$ele.ajaxComplete();
$ele.ajaxStart();
$ele.ajaxStop();
$ele.ajaxSend();
$.param(obj); //對象 對象數組 或jq對象(包含input元素的)
myobj = { a:{one:1, two:2, three:3}, b:[1,2,3]};
decodeURIComponent( $.param(myobj) );
obj = {width:100, height:400};
$.param(obj);
objArr = [{name:'foo', value:'fooval'}, {name:'bar', value:'barVal'}];
$.param(objArr);
$form.serialize();//表單序列化 name1=val1&name2=val2
$('input, textarea, select').serialize();//對包含表單元素的jq對象序列化
$form.serializeArray();//表單序列化爲對象數組 [{name:.., value:..}, {name:.., value:...}]
$('input, textarea, select').serializeArray();//包含表單元素的jq對象序列化
$.ajax(url, [settings]);//返回jqxhr對象,jqxhr實現了 Promise 接口
$.ajax([settings]);
settings = {
accepts: {}, //請求頭的content-type
async: true, //是否異步 注意跨域和jsop不支持異步
beforeSend: function(xhr, settings){}, //請求發送前的回調,若返回false將取消請求
cache: false, //是否緩存請求結果 script和jsonp默認不緩存
complete: function(){},
contents:{}, //根據給定的內容類型,解析結果
contentType: 'application/x-www-form-urlencoded; charset=utf8',
context: obj, //設置相關回調函數的上下文, 回調中this默認指向settings ~~頗有用的說
converters: {
"* text": window.String,
"text html": true,
"text json": jQuery.parseJSON,
"text xml": jQuery.parseXML
},
crossDomain: false, //若要在同域中強制跨域調用 設爲true
data:{}, //object, string, array
dataFilter: function(data, type){}, //過濾返回的數據
dataType: 'json', //json, jsonp, script, text, html, xml,
error: function(xhr, status, err){},
global: false, //是否觸發全局的ajax事件
headers:{}, //額外設置的請求頭數據
ifModified: false, //是否檢查http頭信息if-modify以決定是否成功
isLocal: false,
jsonp:'myjsonp', // myjsonp=? 而不是默認的callback=?
jsonpCallback: 'okcallback', //全局的函數名或匿名函數, ?myjsonp=okcallback
method: 'get', //get post.. jquery1.9添加 同舊參數 type
type:'get',
mimeType:'',
username:'',
password:'',
processData: true, //默認data爲對象,則會轉換爲url參數形式發送
scriptCharset: 'utf-8',
statusCode:{}, //狀態碼對應的回調 {404: 404callback, 200: 200callback},
success: function(data, status, xhr){},
timeout: 3000,
traditional: false, //是否用傳統方式序列化數據
url:''
}
//jqXhr對象是對原生xhr對象的封裝,可經過jqxhr.getResponseHeader()獲取響應頭信息
//jqxhr.setRequestHeader(name, value);
//jqxhr.getAllResponseHeaders();
//jqxhr.getResponseHeader();
//jqxhr.abort();
//jquery1.5開始 jqxhr對象實現 Promise 接口, jqxhr提供了和回調函數名一致的方法 jqxhr.success(), jqxhr.error(), jqxhr.complete()
jqxhr.done(function(data, status, xhr){ }); //替代過期的 jqxhr.success()
jqxhr.fail(function(xhr, status, err){ }); //替代過期的 jqxhr.error()
jqxhr.always(function(data/xhr, status, xhr/err){ });//替代 jaxhr.complete()
jqxhr.then(doneCallback, failCallback);
$.ajaxSetup(options);//設置默認值
$(selector, [context]);
$(domElement);
$(domEles);
$(obj);
$(jqObj);
$(html, owndoc);
$(html, attrs);
$.parseHTML();
$.parseJSON();
$.parseXML();
$.noConflict();
$.sub();//建立jquery副本,其屬性和方法修改不影響原來jquery, (過期方法,用插件替代)
$.when(deferreds); //能夠傳入一個或多個延遲對象,或普通的對象(done回調會被當即執行)
$.when($.get(url1), $.get(url2)).then(function(data1, data2){ });//當傳遞多個延遲對象給when時,實際上會被看作一個新的延遲對象(包含2個延遲)
$.when($.ajax(settings)).then(function(data, status, xhr){ });
$.when({'name':'idle', 'age': 22}).then(function(data){ console.log(data);});//當即resolve,執行doneCallback
$.when().then(function(){ console.log('fire at once');});
var df1 = $.Deferred();
var df2 = $.Deferred();
$.when(df1, df2).then(function(v1, v2){
console.log(v1, v2);
});
df1.resolve('hello');
df2.resolve('boy');
// ------
var d1 = $.Deferred();
var d2 = $.Deferred();
var d3 = $.Deferred();
$.when( d1, d2, d3 ).done(function ( v1, v2, v3 ) {
console.log( v1 ); // v1 is undefined
console.log( v2 ); // v2 is "abc"
console.log( v3 ); // v3 is an array [ 1, 2, 3, 4, 5 ]
});
d1.resolve();
d2.resolve( "abc" );
d3.resolve( 1, 2, 3, 4, 5 );//多個參數,則doneCallback的入參爲數組
// --------
$.when($.ajax("/page1.php"), $.ajax("/page2.php")).done(function(a1, a2){
/* a1 and a2 are arguments resolved for the page1 and page2 ajax requests, respectively */
var jqXHR = a1[2]; /* arguments are [ "success", statusText, jqXHR ] */
if ( /Whip It/.test(jqXHR.responseText) ) {
alert("First page has 'Whip It' somewhere.");
}
});
// Deferred延遲對象 jq1.5引入
var deferred = $.Deferred();
deferred.always(callback1, callback2..); //resolve or reject都執行的回調
$.get('data.php').always(function(){ console.log('complete..');});
deferred.done(calblack1, callback2..); //resolve時執行的回調
$.get('data.php').done(function(){ console.log('success get data');});
deferred.fail(callback1, callback2..); //reject時執行的回調
$.get('data.php').done(function(){ console.log('success');}).fail(function(){ console.log('fail');});
var deferred = $.Deferred();
deferred.resolve('hello');
deferred.state();// resolved
var promise = deferred.promise(); //promise對象是受限的deferred對象,不能經過resolve, reject改變狀態
deferred.notify(args); //觸發 progressCallback的執行
deferred.then(doneCallback, failCallback, progressCallback);
deferred.progress(callback);
deferred.notifyWith(context, [args]); //可指定progressCallback的上下文對象 其餘同df.notify(args)
var df = $.Deferred();
df.progress(function(a){ console.log(this.name, a); });
var p = {name: 'sisi'};
df.notifyWith(p, ['sing']);
deferred.pipe(doneCb, failCb, progressCb); //用 df.then() 代替
var df = $.Deferred();
var df2 = df.pipe(function(value){//pipe返回新的延遲對象, then也是返回新的延遲對象
return value * 2; //舊的延遲對象被resolve,新的延遲對象也會接着resolve, (這裏返回數值或對象則當即resolve新的延遲對象, 若返回另1個延遲對象 如: return $.ajax(url); 則當該延遲對象resolve時,df2跟着resolve)
}).done(function(v){ console.log(v);}); //延遲對象管道方式一個接一個地resolve
df.resolve(5);
//鏈式調用ajax
var request = $.ajax(url, {dataType: 'json'});
var chained = request.pipe(function(data){
return $.ajax(url2, {data: {user: data.userId}});
});
chained.done(function(data){ });
deferred.progress(progressCallback1, progressCallback2);
deferred.promise([targetObj]); //返回promise對象
// example1:
function asyncEvent(){
var dfd = $.Deferred();
setTimeout(function(){
dfd.resolve('great');
}, Math.floor(400+ Math.random()*2000));
setTimeout(function(){
dfd.reject('bad');
}, Math.floor(400+ Math.random()*2000));
setTimeout(function working(){
if(dfd.state() === 'pending'){
dfd.notify('working...');
setTimeout(working, 500);
}
}, 1);
return dfd.promise();
}
$.when( asyncEvent() ).then(
function(arg){
console.log('well', arg);
},
function(arg){
console.log('fail', arg);
},
function(arg){
console.log('going', arg);
}
);
// example2:
var obj = { hello: function(name){ console.log('hello', name); } };
var dfd = $.Deferred();
dfd.promise(obj); //讓obj實現promise接口
dfd.resolve('alice');
obj.done(function(name){ obj.hello(name); }).hello('sisi');
deferred.reject([args]);
deferred.rejectWith(context, [args]);
deferred.resolve(args);
deferred.resolveWith(context, [args]);
deferred.state(); //返回延遲對象當前的狀態:pending resolved rejected
deferred.then(doneCb, failCb, progressCb); //參考 df.pipe()
$ele.promise([type], [targetObj]); // type: 'fx', targetObj: 需綁定promise方法的對象
$('div').each(function(i){
$(this).fadeIn().fadeOut(1000 * (i+1) );//一個接一個div漸隱
});
$('div').promise() //返回promise對象 會在動畫結束後被resolve
.done(function(){ console.log('finished..')});
function effect(){
return $('div').fadeIn(800).delay(1200).fadeOut();
}
$.when( effect() ).done(function(){ console.log('finished..'); });
$.contains(container, contained);//檢測一個元素是否在另外一個元素內 container需爲domElement
$.each(collection, function(key, val){ });//迭代函數 可迭代對象和數組 , 返回false終止迭代
$.extend(target, [object1], [objectN]);
$.extend(deep, target, [object1], [objectN]);//深度拷貝
$.extend({}, src1, src2); //undefined值不會被複制
$.globalEval(code); //在全局上下文執行一些代碼
function test(){
$.globalEval('var newvar = true; ');
}
test();
$.grep(array, function(ele, idx){ return true;}, invert); //相似[].filter, 返回過濾後的新數組
var arr = [ 1, 9, 3, 8, 6, 1, 5, 9, 4, 7, 3, 8, 6, 9, 1 ];
$.grep(arr, function(n, i){ return n> 5; });
$.inArray(value, arr, fromIndex); //相似 [].indexOf();
$.inArray( 5 + 5, [ "8", "9", "10", 10 + "" ] ); // -1 嚴格比較
$.isArray();
$.isEmptyObject(); //{}
$.isPlainObject();//{name:'sisi'}
$.isFunction();
$.isNumeric();
$.isWindow();
$.isXMLDoc(document); //false
$.makeArray();//類數組orjq對象轉換爲數組 ~~$.makeArray(arguments)
$.map(collection, function(ele, key){ });
$.merge(arr1, arr2);//合併數組元素 arr1會被擴展
$.merge([], arr2); //克隆數組
$.merge( [0,1,2], [2,3,4] ); //[0, 1, 2, 2, 3, 4] ~~$.unique( $.merge(arr1, arr2) ) 合併數組並去重
$.noop;
$.now(); // (new Date).getTime()
$.parseHTML(data, [context], [keepScript]);
$.parseJSON(json);//注意傳入的是嚴格的json
$.parseXML(data); //返回xmldoc
$.proxy(fn, context, [args]); //返回爲fn綁定上下文後的新函數, 還可綁定部分參數。相似bind
$.proxy(objec, method); //固定對象方法的上下文爲自身
$.support;//建議用外部庫 modernizr, $.support包含不少特性檢測的結果,如: $.support.ajax, $.support.boxModel
$.trim([str]);
$.type(param); //數據類型判斷
$.type(''); $.type([]); $.type(/test/)
$.unique(arr); //數組或dom元素去重
$ele.get([index]);//返回dom元素 或 dom元素數組 ~~$ele.get() 類數組轉換爲真正的數組
$ele.index(); //表示範圍爲 兄弟節點
$ele.index(selector); //選擇器參數 ,表示查找的範圍
$ele.index(element); //dom元素或jq對象,表示被查找的元素,而$ele表示查找範圍
$ele.toArray(); //同 $ele.get()
$ele.context;
$ele.selector;
$.Callbacks(); //事件處理能力 jq1.7+
$.Callbacks( 'unique stopOnFalse' ); //flags: once, menory,unique, stopOnFalse
var callbacks = $.Callbacks(); //~~建立事件處理中心 比較有用
callbacks.add();
callbacks.remove();
callbacks.fire();
callbacks.disable();
callbacks.empty();
callbacks.fired();
callbacks.fireWith(context, args);
callbacks.has(fn);
callbacks.lock();
callbacks.locked();
function fn1(a){
console.log(a);
}
function fn2(a){
console.log('fn2', a);
}
callbacks.add(fn1);
callbacks.add(fn2);
callbacks.fire('morning');
// $.Callbacks $.Deferred 和 pub/sub 模式,促進代碼鬆耦合
用$.Callbacks()實現觀察者模式
var observer = { hash: {}, subscribe: function(id, callback) { if (typeof id !== 'string') { return } if (!this.hash[id]) { this.hash[id] = $.Callbacks() this.hash[id].add(callback) } else { this.hash[id].add(callback) } }, publish: function(id) { if (!this.hash[id]) { return } this.hash[id].fire(id) } } // 訂閱 observer.subscribe('mailArrived', function() { alert('來信了') }) observer.subscribe('mailArrived', function() { alert('又來信了') }) observer.subscribe('mailSend', function() { alert('發信成功') }) // 發佈 setTimeout(function() { observer.publish('mailArrived') }, 5000) setTimeout(function() { observer.publish('mailSend') }, 10000)
$.Event解析
==============
$.Event(event/type, [props]); 返回可讀寫的jq事件對象 $event
$.event.fix(event); 在內部調用了$.Event構造函數,包裝了原生事件對象
$.cache存儲了全部註冊的事件處理程序,實際上dom元素上的只有一個事件處理程序( $.cache[ele[$.expando]].handle , 其內部用 $.event.dispatch實現對緩存事件處理程序的訪問)
$._data(domEle); 能夠查看dom元素的數據緩存和綁定事件$(domEle).data(); 只能看到數據緩存