bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

怎么在JavaScript中實(shí)現(xiàn)鏈?zhǔn)秸{(diào)用-創(chuàng)新互聯(lián)

怎么在JavaScript中實(shí)現(xiàn)鏈?zhǔn)秸{(diào)用?相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問題。

目前創(chuàng)新互聯(lián)已為1000+的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)絡(luò)空間、網(wǎng)站托管、服務(wù)器租用、企業(yè)網(wǎng)站設(shè)計(jì)、射陽(yáng)網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。

什么是鏈?zhǔn)秸{(diào)用

鏈?zhǔn)秸{(diào)用在 JavaScript 語(yǔ)言界很常見,如 jQuery 、 Promise 等,都是使用的鏈?zhǔn)秸{(diào)用。鏈?zhǔn)秸{(diào)用可以讓我們?cè)谶M(jìn)行連續(xù)操作時(shí),寫出更簡(jiǎn)潔的代碼。

new Promise((resolve, reject) => {
 resolve();
})
.then(() => {
 throw new Error('Something failed');
})
.then(() => {
 console.log('Do this whatever happened before');
})
.catch(() => {
 console.log('Do that');
})

逐步實(shí)現(xiàn)鏈?zhǔn)秸{(diào)用

假設(shè),我們要實(shí)現(xiàn)一個(gè) math 模塊,使之能夠支持鏈?zhǔn)秸{(diào)用:

const math = require('math');
const a = math.add(2, 4).minus(3).times(2);
const b = math.add(2, 4).times(3).divide(2);
const c = { a, b };

console.log(a.times(2) + b + 1); // 22
console.log(a.times(2) + b + 2); // 23
console.log(JSON.stringify(c)); // {"a":6,"b":9}

基本的鏈?zhǔn)秸{(diào)用

鏈?zhǔn)秸{(diào)用通常的實(shí)現(xiàn)方式,就是在函數(shù)調(diào)用結(jié)果返回模塊本身。那么 math 模塊的代碼大致應(yīng)該是這樣子的:

export default {
 add(...args) {
  // add
  return this;
 },
 minus(...args) {
  // minus
  return this;
 },
 times(...args) {
  // times
  return this;
 },
 divide(...args) {
  // divide
  return this;
 },
}

方法如何返回值

上述代碼實(shí)現(xiàn)了鏈?zhǔn)秸{(diào)用,但是也存在一個(gè)問題,就是無(wú)法獲取計(jì)算結(jié)果。所以我們需要對(duì)模塊進(jìn)行改造,使用一個(gè)內(nèi)部變量來(lái)存儲(chǔ)計(jì)算結(jié)果。

export default {
 value: NaN,
 add(...args) {
  this.value = args.reduce((pv, cv) => pv + cv, this.value || 0);
  return this;
 },
}

這樣,我們?cè)谧詈笠徊剑ㄟ^(guò) .value 就可以拿到最終的計(jì)算結(jié)果了。

問題真的解決了嗎

上面我們看似通過(guò)一個(gè) value 變量解決了存儲(chǔ)計(jì)算結(jié)果的問題,但是發(fā)生第二次鏈?zhǔn)秸{(diào)用時(shí), value 的值因?yàn)橐呀?jīng)有了初始值,我們會(huì)得到錯(cuò)誤的計(jì)算結(jié)果!

const a = math.add(5, 6).value; // 11
const b = math.add(5, 7).value; // 23 而非 12

既然是因?yàn)?nbsp;value 有了初始值,那么能不能在獲取 value 的值時(shí)重置掉呢?答案是不能,因?yàn)槲覀儾⒉荒艽_定使用者會(huì)在什么時(shí)候取值。

另外一種思路是在每次鏈?zhǔn)秸{(diào)用之前生成一個(gè)新的實(shí)例,這樣就可以確保實(shí)例之間相互獨(dú)立了。

const math = function() {
 if (!(this instanceof math)) return new math();
};

math.prototype.value = NaN;

math.prototype.add = function(...args) {
 this.value = args.reduce((pv, cv) => pv + cv, this.value || 0);
 return this;
};

const a = math().add(5, 6).value;
const b = math().add(5, 7).value;

但是這樣也不能徹底解決問題,假設(shè)我們?nèi)缦抡{(diào)用:

const m = math().add(5, 6);
const c = m.add(5).value; // 16
const d = m.add(5).value; // 21 而非 16

所以,最終要解決這個(gè)問題,只能每個(gè)方法都返回一個(gè)新的實(shí)例,這樣可確保無(wú)論怎么調(diào)用,相互之間都不會(huì)被干擾到。

math.prototype.add = function(...args) {
 const instance = math();
 instance.value = args.reduce((pv, cv) => pv + cv, this.value || 0);
 return instance;
};

如何支持不通過(guò) .value 對(duì)結(jié)果進(jìn)行普通運(yùn)算

通過(guò)改造 valueOf 方法或者 Symbol.toPrimitive 方法。其中 Symbol.toPrimitive 方法優(yōu)先 valueOf 方法被調(diào)用,除非是ES環(huán)境不支持。

如何支持 JSON.stringify 序列化計(jì)算結(jié)果

通過(guò)自定義 toJSON 方法。 JSON.stringify 將值轉(zhuǎn)換為相應(yīng)的JSON格式時(shí),如果被轉(zhuǎn)換值有 toJSON 方法,則優(yōu)先使用該方法返回的值。

最終的完整實(shí)現(xiàn)代碼

class Math {
 constructor(value) {
  let hasInitValue = true;
  if (value === undefined) {
   value = NaN;
   hasInitValue = false;
  }
  Object.defineProperties(this, {
   value: {
    enumerable: true,
    value: value,
   },
   hasInitValue: {
    enumerable: false,
    value: hasInitValue,
   },
  });
 }

 add(...args) {
  const init = this.hasInitValue ? this.value : args.shift();
  const value = args.reduce((pv, cv) => pv + cv, init);
  return new Math(value);
 }

 minus(...args) {
  const init = this.hasInitValue ? this.value : args.shift();
  const value = args.reduce((pv, cv) => pv - cv, init);
  return new Math(value);
 }

 times(...args) {
  const init = this.hasInitValue ? this.value : args.shift();
  const value = args.reduce((pv, cv) => pv * cv, init);
  return new Math(value);
 }

 divide(...args) {
  const init = this.hasInitValue ? this.value : args.shift();
  const value = args.reduce((pv, cv) => pv / cv, init);
  return new Math(value);
 }

 toJSON() {
  return this.valueOf();
 }

 toString() {
  return String(this.valueOf());
 }

 valueOf() {
  return this.value;
 }

 [Symbol.toPrimitive](hint) {
  const value = this.value;
  if (hint === 'string') {
   return String(value);
  } else {
   return value;
  }
 }
}

export default new Math();

看完上述內(nèi)容,你們掌握怎么在JavaScript中實(shí)現(xiàn)鏈?zhǔn)秸{(diào)用的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道,感謝各位的閱讀!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

本文名稱:怎么在JavaScript中實(shí)現(xiàn)鏈?zhǔn)秸{(diào)用-創(chuàng)新互聯(lián)
文章位置:http://vcdvsql.cn/article18/csccgp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站域名注冊(cè)企業(yè)網(wǎng)站制作定制開發(fā)外貿(mào)網(wǎng)站建設(shè)營(yíng)銷型網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營(yíng)