本篇 jQuery 的 AJAX 是從網路資源與網路平台pluralsight
中的課程所學習。
Utility Methods
$.each
透過$.each()
把陣列或物件中的內容重複取出,再依次去執行 callback。
data:image/s3,"s3://crabby-images/01270/0127096c003acede7883edff6011b6eb57a323d3" alt=""
以下案例為:點擊一個 button,要秀出全部喜愛的城市與圖片。
html
1 2 3 4 5 6 7 8 9
| <div class="favorite-0"> ... </div> <div class="favorite-1"> ... </div> <div class="favorite-2"> ... </div>
|
result 的內容(JSON 格式)
1 2 3 4 5 6 7 8 9 10 11 12
| { image: 'imgaes/paris.png', name: 'Paris, France', }, { image: 'imgaes/london.png', name: 'London, UK', }, { image: 'imgaes/mardird.png', name: 'Madrid, Spain', }
|
用$.each
來迭代 result 這個 JSON 的物件,並將 name 與 image 新增到 html 內容裡面。
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| $("button").on("click", function() { $.ajax("/cities/favorite/1", { contentType: "application/json", dataType: "json", success: function(result) { $.each(result, function(index, city) { var favorite = $(".favorite-" + index); favorite.find("p").html(city.name); favorite.find("img").attr("src", city.image); }); } }); });
|
$.each 官方文件
$.map
$.map
data:image/s3,"s3://crabby-images/75990/7599010d7b52a0150ca489ba0445c3b1b061794b" alt=""
使用 map 創立新數組
ex.1
data:image/s3,"s3://crabby-images/41f55/41f554ce2573fb72e46f8bf8750aadaff5ca6994" alt=""
ex.2
data:image/s3,"s3://crabby-images/0e9ab/0e9ab8d9394fe379b9bf696f9e13d41f1c208442" alt=""
將 return 後的 listItem 指定為statusElements
再塞回整個清單中。
data:image/s3,"s3://crabby-images/40cb4/40cb449c8aab56ab3c06bc56f3d8dbfbf55814e6" alt=""
與$.each
的差異是 map 會把結果以新的數組 return,each 沒有返回值,不會改變其值。
data:image/s3,"s3://crabby-images/f1a71/f1a712b463c0e3dfd4cff1918b78450631d3fe2f" alt=""
$.map 官方文件
detach
data:image/s3,"s3://crabby-images/44bbf/44bbfe1eed7e0c9d81869d877e73940f528d88d4" alt=""
使用 detach 而不使用 remove 來刪除元素,detach 會把選取的元素移除,但是會保留著,還是可以再去使用。
這是一個更有效能的做法,
在上面的例子中改為:
1 2 3 4
| $(".status-list") .detach() .html(statusElements) .appendTo(".status");
|
detach 官方文件
Advanced Events
off
停止去監聽符合條件的事件(通常是用 on 新增的事件)。
data:image/s3,"s3://crabby-images/956aa/956aa9f65d0c64b665ec22d03220e0bc981982fe" alt=""
ex.1 停止全部 click 事件
data:image/s3,"s3://crabby-images/187e3/187e34e5af1bf59cc5d24df65a768d4e240ca78f" alt=""
ex.2 停止單一事件 - 需要應用到 namespacing
data:image/s3,"s3://crabby-images/9cea1/9cea182dbe4e0d1814887ad8709fe72c398fc019" alt=""
ex.3 停止全部相同 namespace 的事件
data:image/s3,"s3://crabby-images/75c4a/75c4a96a67f5fbf563c8c9bf079eb672179ca315" alt=""
trigger
trigger()
用來觸發所指定的事件類型。
ex1. 等同於點擊 button 觸發事件
同時觸發兩個 click 事件
1 2 3 4 5 6 7 8 9 10
| function picture(){console.log('Show Plane');} function status(){console.log('In Service');}
$(document).ready(function(){ $('button').on('click.image', picture); $('button').on('click.details', status); $('button').on('mouseover.image', zoom); ... $('button').trigger('click'); });
|
ex.2 trigger 也可以指定 namespace 來觸發
觸發 image namespace 的 click 事件
1 2 3 4 5 6 7 8 9
| function picture(){console.log('Show Plane');} function status(){console.log('In Service');}
$(document).ready(function(){ $('button').on('click.image', picture); $('button').on('click.details', status); ... $('button').trigger('click.image'); });
|
ex.3 可以trigger自訂的event.namespace
trigger一個按鈕可以觸發所有符合條件項目的function
data:image/s3,"s3://crabby-images/0b94f/0b94ff383bd9d71dbc587f8c4bfac3ac6724e8b4" alt=""
data:image/s3,"s3://crabby-images/19de3/19de33dc19c75de484e94a29ec0f9e5e0fb01684" alt=""