欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

TypeScript交叉運(yùn)算的算法示例解析

 更新時(shí)間:2023年08月04日 11:10:47   作者:Qing  
這篇文章主要為大家介紹了TypeScript交叉運(yùn)算的算法示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

引文

相信只要接觸過ts的同學(xué)就有了解交叉類型這兩個(gè)概念,以前我對(duì)交叉類型感到非常疑惑,明明叫交叉類型,為何對(duì)對(duì)象類型使用了交叉運(yùn)算后類型反而會(huì)進(jìn)行屬性的合并?不知道大家有沒有和我一樣的困惑。這篇文章我會(huì)分享我最近感悟到的用不同視角來解釋出現(xiàn)上述問題的原因,如有錯(cuò)誤,懇請(qǐng)指正。

交叉運(yùn)算

在ts中,使用&這個(gè)符號(hào)來對(duì)兩個(gè)類型進(jìn)行交叉運(yùn)算,下面舉幾個(gè)小例子來開始講解。

例一

type A = number & string    // never

例二

type A = 1 & number                // 1
type B = "hello" & string          // "hello"

例三

type A1 = {a: number}
type A2 = {aa: string}

這里的例子正是我在引文中提到的情況,按照交叉這個(gè)字面意思來理解,{a: number}{aa: string}兩個(gè)好像也沒有什么交集,按照例一的思路來思考,結(jié)果應(yīng)該是never,為何結(jié)果是{a: number, aa: string}?

首先來思考一個(gè)問題,假設(shè)有這么幾個(gè)對(duì)象:

{a: 1, b: 2}

{aa: "11", bb: "22"}

{a: 1, b: 2, aa: "11", bb: "22"}

這幾個(gè)對(duì)象分別賦值給類型為A1、A2、A的變量,哪個(gè)類型的變量在被賦值的時(shí)候有比較大的可能會(huì)出現(xiàn)錯(cuò)誤?

相信大家能夠很容易的猜到答案,那就是上面的這三個(gè)對(duì)象在給類型為A的變量賦值的時(shí)候前兩個(gè)對(duì)象都會(huì)報(bào)錯(cuò),只有最后一個(gè)對(duì)象是符合類型要求的。

上述中的A1、A2類型,A1類型的變量只需要值中有屬性名為a,屬性值類型為number的屬性即可滿足,而A2類型的變量只需要值中有屬性名為aa,屬性值類型為string的屬性即可滿足,而A類型的變量對(duì)值的要求是必須要同時(shí)有a和aa這兩個(gè)屬性。

那么符合A1、A2、A類型的值各有幾個(gè)?可以歸類下

符合A1類型的值:{a: 1, b: 2}、{a: 1, b: 2, aa: "11", bb: "22"}

符合A2類型的值:{aa: "11", bb: "22"}、{a: 1, b: 2, aa: "11", bb: "22"}

符合A類型的值:{a: 1, b: 2, aa: "11", bb: "22"}

可以看到在A1 & A2后得到的A類型,其值相對(duì)于A1和A2這兩個(gè)類型對(duì)應(yīng)的值的范圍是變小的,這也符合交叉運(yùn)算的結(jié)果趨勢(shì)。

我們對(duì)數(shù)學(xué)中的交并集運(yùn)算有著很深的印象,但是數(shù)學(xué)上交并集運(yùn)算作用的對(duì)象卻是具體的數(shù)值,如果把這種思想轉(zhuǎn)換到ts類型上來,其實(shí)不太合適,而是應(yīng)該把這種思想作用到ts類型所對(duì)應(yīng)的值上。

現(xiàn)在用這種思路去思考例一和例二,也是能夠走通的。

交叉運(yùn)算在處理對(duì)象類型的時(shí)候,交叉過后屬性反而增多,初看覺得不對(duì)勁,但轉(zhuǎn)換角度細(xì)想或許能發(fā)現(xiàn)其中的道理。

總結(jié)

交叉運(yùn)算會(huì)導(dǎo)致能夠賦值給結(jié)果類型的變量范圍變小,這個(gè)類型的限制也會(huì)變得更嚴(yán)格。

以上就是TypeScript交叉運(yùn)算示例解析的詳細(xì)內(nèi)容,更多關(guān)于TypeScript交叉運(yùn)算的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • TypeScript逆變之條件推斷和泛型的應(yīng)用示例詳解

    TypeScript逆變之條件推斷和泛型的應(yīng)用示例詳解

    這篇文章主要為大家介紹了TypeScript逆變之條件推斷和泛型的應(yīng)用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • TypeScript交叉運(yùn)算的算法示例解析

    TypeScript交叉運(yùn)算的算法示例解析

    這篇文章主要為大家介紹了TypeScript交叉運(yùn)算的算法示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • typescript難學(xué)嗎?前端有必要學(xué)?該怎么學(xué)typescript

    typescript難學(xué)嗎?前端有必要學(xué)?該怎么學(xué)typescript

    TypeScript代碼與?JavaScript?代碼有非常高的兼容性,無門檻,你把?JS?代碼改為?TS?就可以運(yùn)行。TypeScript?應(yīng)該不會(huì)脫離?JavaScript?成為獨(dú)立的語言。學(xué)習(xí)?TypeScript?應(yīng)該主要指的是學(xué)習(xí)它的類型系統(tǒng)。
    2022-12-12
  • typescript 支持與本地調(diào)試配置詳解

    typescript 支持與本地調(diào)試配置詳解

    這篇文章主要為大家介紹了typescript 支持與本地調(diào)試配置詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • 簡(jiǎn)單三行代碼函數(shù)實(shí)現(xiàn)幾十行Typescript類型推導(dǎo)

    簡(jiǎn)單三行代碼函數(shù)實(shí)現(xiàn)幾十行Typescript類型推導(dǎo)

    這篇文章主要為大家介紹了簡(jiǎn)單三行代碼函數(shù)實(shí)現(xiàn)幾十行Typescript類型推導(dǎo)的方案示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • Typescript tsconfig.json的配置詳情

    Typescript tsconfig.json的配置詳情

    這篇文章主要為大家介紹了Typescript tsconfig.json的配置詳情示例 ,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • typescript快速上手的基礎(chǔ)知識(shí)篇

    typescript快速上手的基礎(chǔ)知識(shí)篇

    靜態(tài)類型的typescript與傳統(tǒng)動(dòng)態(tài)弱類型語言javascript不同,在執(zhí)行前會(huì)先編譯成javascript,因?yàn)樗鼜?qiáng)大的type類型系統(tǒng)加持,能讓我們?cè)诰帉懘a時(shí)增加更多嚴(yán)謹(jǐn)?shù)南拗啤W⒁?,它并不是一門全新的語言,所以并沒有增加額外的學(xué)習(xí)成本
    2022-12-12
  • 數(shù)據(jù)結(jié)構(gòu)Typescript之哈希表實(shí)現(xiàn)詳解

    數(shù)據(jù)結(jié)構(gòu)Typescript之哈希表實(shí)現(xiàn)詳解

    這篇文章主要為大家介紹了數(shù)據(jù)結(jié)構(gòu)Typescript之哈希表實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • Spartacus中navigation?item?reducer實(shí)現(xiàn)解析

    Spartacus中navigation?item?reducer實(shí)現(xiàn)解析

    這篇文章主要為大家介紹了Spartacus中navigation?item?reducer實(shí)現(xiàn)解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • 微信小程序?qū)崿F(xiàn)圖片自適應(yīng)(支持多圖)

    微信小程序?qū)崿F(xiàn)圖片自適應(yīng)(支持多圖)

    這篇文章主要介紹了微信小程序如何實(shí)現(xiàn)圖片自適應(yīng)的相關(guān)資料,文中介紹的方法同樣適應(yīng)于多圖,有需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-01-01

最新評(píng)論