国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

如何利用Promises編寫更優雅的JavaScript代碼

2019-11-20 10:01:42
字體:
來源:轉載
供稿:網友

你可能已經無意中聽說過 Promises,很多人都在討論它,使用它,但你不知道為什么它們如此特別。難道你不能使用回調么?有什么了特別的?在本文中,我們一起來看看 Promises 是什么以及如何使用它們寫出更優雅的 JavaScript 代碼。

Promises 易于閱讀

比如說我們想從 HipsterJesus 的API中抓取一些數據并將這些數據添加到我們的頁面中。這些 API 的響應數據形式如下:

{  "text": "<p>Lorem ipsum...</p>",  "params": {  "paras": 4,  "type": "hipster-latin" }} 

要使用回調的話,我們通常要寫如下形式的東西:

$.getJSON('http://hipsterjesus.com/api/', function(data) {  $('body').append(data.text); }); 

如果你有 jQuery 的使用經歷,你會認出我們創建了一個 GET 請求并且希望響應內容是 JSON。我們還傳遞了一個回調函數來接受響應的 JSON,以將數據添加到文檔中。

另外一種書寫方法是使用 getJSON 方法返回的 promise 對象。你可以直接在這個返回對象上綁定一個回調。

var promise = $.getJSON('http://hipsterjesus.com/api/');promise.done(function(data) {  $('body').append(data.text); }); 

在上面的回調例子中,當響應成功時它將 API 請求的結果添加到文檔中。但當響應失敗是會發生什么呢?我們可以在我們的 promise 上綁定一個失敗處理器。

var promise = $.getJSON('http://hipsterjesus.com/api/');promise.done(function(data) {  $('body').append(data.text);});promise.fail(function() {  $('body').append('<p>Oh no, something went wrong!</p>'); }); 

大多數人刪掉了 promise 變量,這樣更簡潔,一眼就能看出代碼的作用。

$.getJSON('http://hipsterjesus.com/api/').done(function(data) {  $('body').append(data.text);}).fail(function() {  $('body').append('<p>Oh no, something went wrong!</p>'); }); 

jQuery 也包含一個一直發生的事件處理器,不論請求成功失敗都會被調用。

$.getJSON('http://hipsterjesus.com/api/').done(function(data) {  $('body').append(data.text);}).fail(function() {  $('body').append('<p>Oh no, something went wrong!</p>');}).always(function() {  $('body').append('<p>I promise this will always be added!.</p>'); }); 

通過使用promise,回調的順序是按預期的。我們能確保正常回調先被調用,然后是失敗回調,最后是一直發生的回調。

更好的 API

比如說我們想創造一個 HipsterJesus API 的封裝對象。我們會添加一個方法――html,它將來自 API 的 HTML 數據返回。與之前設置一個回調處理器來解析請求不同,我們可以讓方法返回一個 promise 對象。

var hipsterJesus = {  html: function() {   return $.getJSON('http://hipsterjesus.com/api/').then(function(data) {    return data.text;   }); }}; 

這個做法很酷,這樣我們可以繞過 promise 對象而不必擔心何時或如何解析它的值。任何需要 promise 返回值的代碼只需注冊一個成功響應回調即可。

then方法允許我們修改promise的結果并將其傳遞給鏈中的下一個處理器。這意味現在我們可以這樣使用新的API:

hipsterJesus.html().done(function(html) {  $("body").append(html); }); 

直到最近,AngularJS 出現了一個殺手級特性,模板可以直接綁定到promise。在Angular的控制器中,像這樣:

$scope.hipsterIpsum = $http.get('http://hipsterjesus.com/api/'); 

這樣,在模板中寫 {{ hipsterIpsum.text }} 就很簡單了。當 promise 解析后,Angular 不需要自動更新視圖。不幸的是 Angular 團隊已經放棄了這一特性?,F在,它可以通過調用 $parseProvider.unwrapPromises(true) 來啟用。我希望Angular已經其他框架一直包含此特性(我會一直留意)。

鏈式調用

Promise 最出彩的部分是你可以將它們串聯起來。比如說我們想添加一個方法到一個返回一段數組的 API。

var hipsterJesus = {   html: function() {   return $.getJSON('http://hipsterjesus.com/api/').then(function(data) {    return data.text;   });  },   paragraphs: function() {   return this.html().then(function(html) {    return html.replace(/<[^>]+>/g, "").split("");   });  }}; 

我們以上面的方式這種 HTML 方法,我們用它在 paragraphs 方法中。因為promise回調函數的返回值將傳遞給鏈中的下一個回調,我們能夠在通過它們時自由地創建小的、功能性的方法來改變數據。

我們可以按需求任意次串聯promise。讓我們添加一個。

var hipsterJesus = {   html: function() {   return $.getJSON('http://hipsterjesus.com/api/').then(function(data) {    return data.text;   });  },   paragraphs: function() {   return this.html().then(function(html) {    return html.replace(/<[^>]+>/g, "").split("");   });  },   sentences: function() {   return this.paragraphs().then(function(paragraphs) {    return [].concat.apply([], paragraphs.map(function(paragraph) {     return paragraph.split(/. /);    }));   });  }};  

多個調用

可能 promise 最顯著的特點是調用多個 API 的能力。當使用回調時,如果你需要同時創建兩個API調用時會發生什么呢?你可能會這樣寫:

var firstData = null;var secondData = null;var responseCallback = function() {   if (!firstData || !secondData)   return;   // do something}$.get("http://example.com/first", function(data) {  firstData = data;  responseCallback();});$.get("http://example.com/second", function(data) {  secondData = data;  responseCallback(); }); 

使用 promise 的話,這就簡單多了:

var firstPromise = $.get("http://example.com/first"); var secondPromise = $.get("http://example.com/second"); $.when(firstPromise, secondPromise).done(function(firstData, secondData) {  // do something }); 

這里我們使用 when 方法,將其綁定到一個供兩個請求都完成時調用的處理器上。

結論

這就是 Promise。希望你馬上就想到一些可以用 Promise 實現的的可怕的事情。你最喜歡使用它們的方式是什么?在評論中告訴我吧!

*注:為簡單起見,本文使用了jQuery的延期執行。jQuery 的 Deferred對象 和 Promises/A+的規范 間有細微的差別,這個規范更標準。

以上這篇如何利用Promises編寫更優雅的JavaScript代碼就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 玛多县| 临朐县| 北宁市| 北海市| 阜南县| 巫山县| 鞍山市| 鹿泉市| 宁明县| 宁都县| 招远市| 隆昌县| 舟曲县| 哈密市| 建昌县| 江西省| 黑河市| 枣强县| 彩票| 靖边县| 绵阳市| 宁远县| 西峡县| 邻水| 凌海市| 莆田市| 巴塘县| 大安市| 新宁县| 宜宾县| 资溪县| 阜南县| 北宁市| 色达县| 疏勒县| 武威市| 霍城县| 安阳县| 奇台县| 安泽县| 马鞍山市|