当前位置: 首页 > Web前端 > HTML

精读《type challenges - easy》

时间:2023-03-27 23:26:54 HTML

TS寮虹被鍨嬮潪甯稿ソ鐢紝浣嗗湪瀹為檯浣跨敤涓紝闅惧厤浼氶亣鍒颁竴浜涢毦浠ユ弿杩帮紝鍙嶅闃呰瀹樻柟鏂囨。鏃犳硶瑙e喅鐨勯棶棰樸€傝縿浠婁负姝紝杩樻病鏈変竴涓枃妗f垨涓€濂楁暀鏉愬彲浠ヨВ鍐虫墍鏈夐棶棰樸€傝鍨嬮棶棰樸€備负浠€涔堜細杩欐牱锛熷洜涓篢S涓嶆槸涓€涓畝鍗曠殑鏍囨敞鍣紝鑰屾槸涓€涓浘鐏靛畬澶囩殑璇█锛屾墍浠ュ緢澶氶棶棰樼殑瑙e喅鏂规硶閮介殣钘忓湪鍩虹鑳藉姏涓紝浣嗘槸瀛︿簡鍩虹鑳藉姏浣犲彲鑳芥兂涓嶅埌瑕佺敤鍩虹鑳藉姏銆傝В鍐宠繖涓棶棰樻渶濂界殑鏂规硶灏辨槸澶氱粌涔狅紝閫氳繃瀹為檯妗堜緥涓嶆柇鍒烘縺浣犵殑澶ц剳锛岃浣犲吇鎴怲S鎬濈淮涔犳儻銆傚洜姝わ紝浜嬩笉瀹滆繜锛岃鎴戜滑浠庝粖澶╃殑绫诲瀷鎸戞垬鐨勭畝鍗曢毦搴﹀紑濮嬨€傜簿璇籔ick鎵嬪姩瀹炵幇鍐呯疆鐨凱ick鍑芥暟锛岃繑鍥炰竴涓柊鐨勭被鍨嬶紝浠庡璞:interfaceTodo{title:stringdescription:stringcompleted:boolean}typeTodoPreview=MyPick<寰呭姙浜嬮」锛?鏍囬'|'completed'>consttodo:TodoPreview={title:'Cleanroom',completed:false,}缁撳悎渚嬪瓙鏇村鏄撶悊瑙o紝鍗矺鏄竴涓瓧绗︿覆锛屾垜浠渶瑕佽繑鍥炰竴涓柊鐨勭被鍨嬶紝鍙繚鐣橩閿殑瀹氫箟銆傜涓€涓毦鐐规槸濡備綍闄愬埗K鐨勫€硷紝姣斿浼犲叆涓€涓猅涓笉瀛樺湪鐨勫€硷紝灏变細鎶ラ敊銆傝繖涓祴璇曟槸纭煡璇嗭紝鍙鐭ラ亾AextendskeyofB鐨勮娉曞氨鍙互鎯宠捣鏉ヤ簡銆傜浜屼釜闅剧偣鏄浣曠敓鎴愪竴涓彧鍖呭惈K鐨勭被鍨嬫潵瀹氫箟Key銆備綘棣栧厛闇€瑕佺煡閬搟[AinkeyofB]:B[A]}鐨勭‖鐭ヨ瘑锛岃繖鏍锋墠鑳介噸缁勪竴涓璞★細//浠g爜1typeFoo={[PinkeyofT]:T[P]}鍙煡閬撹繖涓娉曞彲鑳芥兂涓嶅嚭鏉ワ紝鍘熷洜鏄綘瑕佹墦鐮村TS鐨勬鏉跨悊瑙o紝[KinkeyofT]涓嶆槸涓€涓浐瀹氱殑妯℃澘锛屽叾涓璳eyofT鍙槸涓€涓紩鐢ㄥ彉閲忥紝鍙互琚浛鎹€傚鏋滄崲鎴愬彟涓€涓寖鍥寸殑鍙橀噺锛岄偅涔堣繖涓璞$殑閿€艰寖鍥村氨浼氭敼鍙橈紝鍒氬ソ绗﹀悎鏈鐨凨锛?/浠g爜2锛堟湰棰樼瓟妗堬級typeMyPick={[PinK]:T[P]}杩欓亾棰樼煡閬撶瓟妗堝悗寰堝鏄撶悊瑙o紝浣嗗洖鎯宠捣鏉ヨ繕鏄緢鏈夋敹鑾风殑銆傚姣斾笂闈袱涓唬鐮佷緥瀛愶紝浣犱細鍙戠幇浠g爜1涓殑keyofT鍙槸浠庡璞℃弿杩扮殑娉涘瀷瀹氫箟涓彁鍒扮殑锛屾墍浠ュ姛鑳戒笂娌℃湁鍙樺寲锛屼絾鏄洜涓烘硾鍨嬪彲浠ョ敱鐢ㄦ埛浼犲叆锛屾墍浠ヤ唬鐮?涓璳eyofT涓殑P娌℃湁娉涘瀷鏀寔锛屾墍浠ヨ繖閲屾帹瀵间簡T鐨勬墍鏈塊ey锛岃€屼唬鐮?锛岃櫧鐒朵唬鐮佺Щ鍒颁簡娉涘瀷涓婏紝浣嗘槸鍥犱负浣跨敤浜唀xtends鎻忚堪锛屾墍浠ヨ〃绀虹殑绫诲瀷P琚害鏉熶负T鐨凨eys锛岃嚦浜庢槸浠€涔堬紝瑕佺湅鐢ㄦ埛浠g爜鏄€庝箞浼犻€掔殑銆傛墍浠ュ叾瀹濳鍦ㄦ硾鍨嬩腑鏄病鏈夐粯璁ゅ€肩殑锛屼絾鏄畠浣滀负鎺ㄥ鍊煎啓鍏ュ璞℃椂鏄湁榛樿鍊肩殑銆傛硾鍨嬩腑璧嬩簣榛樿鍊肩殑鏂瑰紡濡備笅锛?/浠g爜3typeMyPick={[PinK]:T[P]}鍗矼yPick涔熸槸鍙互姝e父宸ヤ綔鐨勶紝骞朵笖杩斿洖鐨凾odo绫诲瀷涓嶅彉锛屼篃灏辨槸璇翠唬鐮?鍦ㄤ笉浼犵浜屼釜鍙傛暟鐨勬儏鍐典笅锛屽拰浠g爜1鐨勫姛鑳芥槸瀹屽叏涓€鏍风殑銆備粩缁嗙悽纾ㄤ竴涓嬪叡鎬т笌宸紓锛屼负浠€涔堜唬鐮?鍙互瀹炵幇鍜屼唬鐮?涓€鏍风殑鍔熻兘锛屽苟涓旀墿灞曟€ф洿寮猴紝浣犲TS娉涘瀷鐨勫疄闄呯悊瑙d細鏇翠笂涓€灞傛ゼ銆俁eadonly鎵嬪姩瀹炵幇鍐呯疆鐨凴eadonly鍑芥暟灏嗗璞$殑鎵€鏈夊睘鎬ц缃负鍙锛歩nterfaceTodo{title:stringdescription:string}consttodo:MyReadonly={title:"Hey",description:"foobar"}todo.title="Hello"//Error:cannotreassignareadonlypropertytodo.description="barFoo"//Error:cannotreassignareadonlyproperty杩欓亾棰樻瘮绗竴棰樼畝鍗曪紝鍙鎴戜滑use{[AinkeyofB]:B[A]}閲嶆柊澹版槑瀵硅薄锛屽湪姣忎釜Key鍓嶉潰鍔犱笂readonly淇グ锛?/鏈绛旀typeMyReadonly={readonly[KinkeyofT]:T[K]}鏍规嵁杩欎釜Features鎴戜滑鍙互鍋氬緢澶氭墿灞曪紝姣斿鎶婂璞$殑鎵€鏈塳ey璁剧疆涓簅ptional:typeOptional={[KinkeyofT]?:T[K]}{[AinkeyofB]:B[A]}璁╂垜浠湁鏈轰細鎻忚堪姣忎釜Key灞炴€х殑缁嗚妭锛屾垜浠彧鍙楅檺浜庢垜浠殑鎯宠薄鍔涖€侳irstOfArray瀹炵幇绫诲瀷First锛屽苟鑾峰彇鏁扮粍涓涓€椤圭殑绫诲瀷锛歵ypearr1=['a','b','c']typearr2=[3,2,1]typehead1=First//expectedtobe'a'typehead2=First//expectedtobe3杩欓亾棰樻瘮杈冪畝鍗曪紝绛旀涔熷緢瀹规槗鎯冲埌锛?/杩欓亾棰樼殑绛旀绫诲瀷First=T[0]浣嗘槸褰撴垜鍐欒繖涓瓟妗堢殑鏃跺€欙紝10%鐨勮剳缁嗚優鎻愰啋鎴戞病鏈夊垽鏂竟鐣屾潯浠躲€傛灉鐒剁湅浜嗙瓟妗堬紝搴旇鑰冭檻绌烘暟缁勭殑鎯呭喌銆傚綋鏁扮粍涓虹┖鏃讹紝杩斿洖绫诲瀷never鑰屼笉鏄痷ndefined浼氭洿濂姐€備笅闈㈠嚑绉嶄袱绉嶅啓娉曢兘鏄瓟妗堬細typeFirst=Textends[]?浠庝笉锛歍[0]typeFirst=T['length']extends0?浠庝笉锛歍[0]typeFirst=Textends[inferP,...inferRest]?P:never绗竴绉嶅啓娉曟槸閫氳繃extends[]鍒ゆ柇T鏄惁涓虹┖鏁扮粍锛屽鏋滄槸鍒欒繑鍥瀗ever銆傜浜岀鍐欐硶鍒ゆ柇涓€涓暱搴︿负0鐨勭┖鏁扮粍锛岃繖鏃跺€欓渶瑕佹槑鐧戒袱鐐癸細1.TS鍙互閫氳繃T['length']鏉ヨ闂€糽ength(type),2.extends0琛ㄧず鏄惁鍖归厤0锛屽嵆extends闄や簡鍙互鍖归厤绫诲瀷锛岃繕鍙互鐩存帴鍖归厤鍊笺€傜涓夌鍐欐硶鏈€鐪佸績锛屼絾鏄篃鐢ㄥ埌浜唅nfer鍏抽敭瀛椼€傚嵆浣夸綘瀹屽叏鐭ラ亾濡備綍浣跨敤infer锛堢簿璇汇€奣ypescript infer 鍏抽敭瀛椼€嬶級锛屼篃寰堥毦鎯冲嚭鏉ャ€備娇鐢╥nfer鐨勫師鍥犳槸锛氳繖涓満鏅湁杈圭晫鏉′欢锛屾渶瀹规槗鐞嗚В鐨勫啓娉曟槸鈥淚fTisshapelike鈥濓紝閭d箞鎴戝氨杩斿洖绫诲瀷P锛屽惁鍒欏氨杩斿洖returnnever鈥濓紝杩欏彞璇濆湪TS涓槸杩欐牱鎻忚堪鐨勶細Textends[inferP,...inferRest]?P:never銆侺engthofTuple瀹炵幇绫诲瀷Length浠ヨ幏鍙栧厓缁勭殑闀垮害锛歵ypetesla=['tesla','model3','modelX','modelY']typespaceX=['FALCON9','FALCONHEAVY','DRAGON','STARSHIP','HUMANSPACEFLIGHT']typeteslaLength=Length//expected4typespaceXLength=Length//expected5鐮旂┒浜嗗墠闈㈢殑闂锛屽緢瀹规槗鎯冲埌绛旀鐨勭被鍨嬶細typeLength=T['length']瀵逛簬TS锛屽厓缁勫拰鏁扮粍閮芥槸鏁扮粍锛屼絾鏄浜嶵S锛屽彲浠ヨ瀵熷埌鍏冪粍鐨勯暱搴︼紝瀵逛簬T['length']瀵逛簬鍏冪粍锛屽畠杩斿洖涓€涓壒瀹氱殑鍊硷紝浣嗗浜庢暟缁勶紝瀹冭繑鍥炰竴涓暟瀛椼€侲xclude瀹炵幇浜咵xclude绫诲瀷锛岃繑鍥濼涓璘涓笉瀛樺湪鐨勯儴鍒嗐€傝鍑芥暟涓昏鐢ㄤ簬鑱斿悎绫诲瀷鍦烘櫙锛屾墍浠ユ垜浠彲浠ョ洿鎺ヤ娇鐢╡xtends鍒ゆ柇锛?/鏈绛旀绫诲瀷鎺掗櫎=T鎵╁睍U?never:T瀹為檯杩愯鏁堟灉锛歵ypeC=Exclude<'a'|'b','a'|'c'>//'b'濂藉儚鏈夌偣闅剧悊瑙o紝鍥犱负TS鏄寜鍒嗗竷寮忛€熺巼鎵ц鑱斿悎绫诲瀷鐨勶紝鍗筹細Exclude<'a'|'b','a'|'c'>//鐩稿綋浜庢帓闄?'a','a'|'c'>|鎺掗櫎<'b','a'|'c'>Awaited瀹炵幇绫诲瀷Awaited锛屾瘮濡備粠Promise寰楀埌ExampleType銆傞鍏堬紝TS姘歌繙涓嶄細鎵ц浠g爜锛屾墍浠ヤ綘鑴戝瓙閲屼笉瑕佹湁鈥渁wait瑕佺瓑涓€浼氭墠鑳界煡閬撶粨鏋溾€濈殑鎯虫硶銆傝繖閬撻鐨勫叧閿槸浠嶱romise涓彁鍙栫被鍨婽锛岄潪甯搁€傚悎infer:typeMyAwaited=TextendsPromise?U:never浣嗘槸锛岃繖涓瓟妗堜笉澶熸爣鍑嗐€傛爣鍑嗙瓟妗堣€冭檻Promise鐨勫祵濂楀満鏅細//鏈绛旀绫诲瀷MyAwaited>=TextendsPromise?P鎵╁睍Promise锛烳yAwaited

:P:never濡傛灉鑾峰彇鍒癙romise

P涔熷舰濡侾romise锛岄€掑綊璋冪敤鑷繁MyAwaited

銆傝繖閲屾彁鍒颁簡閫掑綊锛屽氨鏄疶S绫诲瀷鐨勫鐞嗗彲浠ラ€掑綊锛屾墍浠ュ悗闈㈡湁灏鹃€掑綊浼樺寲鐨勭増鏈€傚鏋滃疄鐜扮被鍨婭f锛屽綋C涓虹湡鏃惰繑鍥濼锛屽惁鍒欒繑鍥濬锛歵ypeA=If//expectedtobe'a'typeB=If//搴旇鏄?b'鍓嶉潰宸茬粡璇翠簡锛宔xtends涔熷彲浠ョ敤鏉ュ垽鏂€硷紝鎵€浠ユ灉鏂敤extendstrue鍒ゆ柇鏄惁鍛戒腑true锛?/绛旀瀵逛簬杩欎釜闂绫诲瀷If=Cextendstrue?T:FConcat浣跨敤绫诲瀷绯荤粺瀹炵幇Concat锛岃繛鎺ヤ袱涓暟缁勭被鍨嬶細typeResult=Concat<[1],[2]>//棰勬湡涓篬1,2]鍥犱负TS鏀寔鏁扮粍瑙f瀯璇硶涓婏紝鍙互澶ц儐灏濊瘯杩欐牱鍐欙細typeConcat=[...P,...Q]鑰冭檻鍒癈oncat鍑芥暟涔熷簲璇ュ彲浠ユ帴鍙楅潪-鏁扮粍绫诲瀷锛屾垜鍋氫簡鍒ゆ柇銆備负浜嗗啓鐨勬柟渚匡紝鎴戞妸extends浠庢硾鍨嬪畾涔夌殑浣嶇疆绉诲埌浜員S绫诲瀷鎺ㄦ柇鐨勮繍琛屾椂锛?/鏈绛旀typeConcat=[...Pextendsany[]?P:[P],...Qextendsany[]?Q:[Q],]瑙e喅杩欎釜闂闇€瑕佷俊蹇碉紝鎴戠浉淇S鑳藉儚JS涓€鏍峰啓鍑洪€昏緫銆傝繖浜涜兘鍔涙槸鍦ㄧ増鏈崌绾х殑杩囩▼涓€愭笎鎻愪緵鐨勶紝鎵€浠ラ槄璇绘渶鏂扮殑TS鐗规€у苟蹇€熺悊瑙e畠浠綔涓哄浐鍖栫煡璇嗚繕鏄湁闅惧害鐨勩€侷ncludes浣跨敤绫诲瀷绯荤粺瀹炵幇Includes鍑芥暟锛歵ypeisPillarMen=Includes<['Kars','Esidisi','Wamuu','Santana'],'Dio'>//搴旇鏄痐false`鐢变簬涔嬪墠鏍规嵁鎴戠殑缁忛獙锛屽緢瀹规槗鍋氬嚭浠ヤ笅鍏宠仈锛?/濡傛灉鏍囬闇€瑕佽繖绉嶇被鍨媔sPillarMen=Includes<'Kars'|'鍩冭タ杩柉'|'Wamuu'|'Santana','Dio'>//閭f垜鍙互鐢╡xtends杞绘澗瑙e喅绫诲瀷闂Includes=KextendsT?true:false涓嶅垢鐨勬槸锛岀涓€涓緭鍏ユ槸鏁扮粍绫诲瀷锛宔xtends涓嶆敮鎸佸垽鏂€滄暟缁勫寘鍚€濈殑閫昏緫銆傝繖鏃跺€欐垜浠渶瑕佷簡瑙d竴涓柊鐨勭煡璇嗙偣锛岄偅灏辨槸TS鍒ゆ柇[number]涓嬫爣銆備笉浠呮槸杩欓亾棰橈紝浠ュ悗寰堝闅剧偣棰橀兘闇€瑕佸畠浣滀负鍩虹鐭ヨ瘑銆俒number]涓嬫爣琛ㄧず浠绘剰涓€椤癸紝extendsT[number]鍙互瀹炵幇鏁扮粍鍖呭惈鐨勫垽鏂紝鎵€浠ヤ笅闈㈢殑鏂规鏄湁鏁堢殑锛歵ypeIncludes=KextendsT[number]?true:false浣嗘槸缈讳簡涓€涓嬬瓟妗堬紝鍙戠幇杩欎笉鏄爣鍑嗙瓟妗堛€傛垜鐪熺殑鎵惧埌浜嗕竴涓弽渚嬶細typeIncludes=KextendsT[number]?true:falsetypeisPillarMen=Includes<[boolean],false>//涓簍rue鐨勫師鍥犲緢绠€鍗曘€倀rue鍜宖alse閮界户鎵胯嚜boolean锛屾墍浠xtends鍒ゆ柇鐨勭晫闄愬お瀹戒簡銆傝棰樿姹傜簿纭€煎尮閰嶏紝鎵€浠ヤ笂闈㈢殑绛旀鐞嗚涓婃槸閿欒鐨勩€傛爣鍑嗙瓟妗堟槸姣忔鍒ゆ柇鏁扮粍绗竴椤癸紝閫掑綊锛堟垜鐪熺殑瑙夊緱杩欎笉鏄竴閬撳鏄撶殑棰橈級锛屾湁涓や釜闅剧偣銆侲qual鍑芥暟鍏堟€庝箞鍐欙紵鏇存祦琛岀殑鏂规鏄繖鏍风殑锛歵ypeEqual=(()=>TextendsX?1:2)extends(()=>TextendsY?1:2)?true:false杩樻湁涓€涓叧浜庡浣曠紪鍐橢qual鍑芥暟鐨勫皬璁ㄨ銆備笂闈㈢殑浠g爜鏋勯€犱簡涓や釜鍑芥暟銆傝繖涓や釜鍑芥暟涓殑T灞炰簬deferred锛堝欢杩燂級鍒ゆ柇鐨勭被鍨嬶紝绫诲瀷鍒ゆ柇渚濊禆浜庡唴閮ㄧ殑isTypeIdenticalTo鍑芥暟鏉ュ畬鎴愬垽鏂€傛湁浜咵qual锛屽氨寰堢畝鍗曚簡锛屾垜浠彲浠ョ敤瑙f瀯+鎺ㄧ悊+閫掑綊鏉ユ悶瀹氾細//杩欓亾棰樼殑绛旀绫诲瀷Includes=Textends[inferF,...inferRest]?绛変簬寤朵几鐪燂紵true:Includes:false姣忔鍙栨暟缁勭殑绗竴涓€煎垽鏂槸鍚︾浉绛夛紝濡傛灉涓嶅尮閰嶏紝鍒欓€掑綊鍒ゆ柇鍏朵綑椤广€傝繖涓嚱鏁扮粨鍚堜簡寰堝TS鐭ヨ瘑锛屾瘮濡傦細閫掑綊瑙f瀯inferextendstrue鍙互鍙戠幇锛屼负浜嗚В鍐硉rueextendsboolean涓簍rue鐨勯棶棰橈紝缁曚簡涓€澶у湀锛岀敤浜嗘瘮杈冨鏉傜殑鏂瑰紡鏉ュ疄鐜帮紝鍦═S浣撴搷涓篃鏄甯哥殑锛岃В鍐抽棶棰橀渶瑕佽€愬績銆侾ushimplementsPushfunction:typeResult=Push<[1,2],'3'>//[1,2,'3']杩欓亾棰樼湡鐨勫緢绠€鍗曪紝鐢ㄨВ鏋勫氨鍙互浜嗭細//绛旀tothisquestionistypePush=[...T,K]鍙互鐪嬪嚭锛屽鏋滀綘鎯宠交鏉捐В鍐充竴涓畝鍗曠殑TS闂锛屼綘棣栧厛闇€瑕佽兘澶熻В鍐充竴浜涘洶闅剧殑闂闂馃榿銆俇nshift瀹炵幇浜哢nshift鍑芥暟锛歵ypeResult=Unshift<[1,2],0>//[0,1,2,]鍙槸鍦≒ush鐨勫熀纭€涓婃敼鍙樹簡椤哄簭锛?/鏈绛旀typeUnshift=[K,...T]Parameters瀹炵幇浜嗗唴缃嚱鏁癙arameters锛歅arameters鍙互寰楀埌鍑芥暟鐨勫弬鏁扮被鍨嬶紝鍙互鐩存帴鐢╥nfer瀹炵幇锛屽嵆涔熺浉瀵圭畝鍗曪細typeParameters=Textends(...args:inferP)=>any?P:[]infer浠庝换鎰忕壒瀹氫綅缃彇鍊奸潪甯告柟渚匡紝鏄吀鍨嬬殑闅炬噦濂界敤鐨勮娉曘€傚涔犱簡TS鐨勫熀鏈娉曞悗锛岀伒娲昏繍鐢ㄦ槸鍏抽敭銆傝璁哄湴鍧€涓猴細绮捐銆妕ype challenges - easy銆嬄风422鏈熉穌t-fe/weekly鎯冲弬涓庤璁虹殑璇锋埑杩欓噷锛屾瘡鍛ㄩ兘鏈夋柊璇濋锛屽懆鏈垨鍛ㄤ竴鍙戝竷銆傚墠绔簿璇烩€斺€斿府浣犺繃婊ら潬璋辩殑鍐呭銆傚叧娉ㄥ墠绔簿璇诲井淇″叕浼楀彿鐗堟潈澹版槑锛氬厤璐硅浆杞?闈炲晢涓?闈炶鐢熶繚鐣欏睘鎬э紙CreativeCommons3.0License锛?/p>