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

React中的这个TS秀给我看

时间:2023-03-29 12:20:06 HTML

鏉ユ簮锛歨ttps://juejin.cn/post/705294...浣滆€咃細AngusAngus鍓嶈█鏈€杩戝湪鍐橰eact瀹氫箟鍙橀噺绫诲瀷鐨勬椂鍊欙紝涓嶅皬蹇冪偣鍒颁簡ElementType锛屽彂鐜皀ode_modules/@types/react/index.d.ts涓殑杩欐浠g爜锛氬お妫掍簡锛岃櫧鐒舵垜涓嶆槸寰堢悊瑙o紝浣嗘垜鍙槸瑙夊緱瀹冨緢妫掋€俫oogle浜嗕竴涓嬶紝鍚庢潵google浜嗕竴涓嬶紝鍙戠幇杩欎釜鍦ㄧ綉涓婂彨绫诲瀷杩囨护锛屾槸涓€绉嶅疄鐢ㄧ殑鍐橳S鐨勬柟娉曘€俓鐪嬩笅闈㈢殑馃尠锛歩nterfaceExample{a:string;b锛氭暟瀛楋紱c锛氭暟瀛楋紱d锛氬瓧绗︿覆锛?..}澶嶅埗浠g爜鎴戜滑鏈変竴涓狤xample鎺ュ彛锛屼絾鏄幇鍦ㄦ垜浠兂瀵硅繖涓帴鍙e仛涓€浜涘鐞嗭紝鎴戜滑鍙兂鐣欎笅string绫诲瀷鐨勫睘鎬э紝閭f€庝箞鍔炲憿锛熸偍鍙互浣跨敤鎴戜滑鑷繁瀹氫箟鐨凢ilterType銆倀ypenewExample=FilterType//{a:string;d:string;...}澶嶅埗浠g爜璁╂垜浠湅鐪婩ilterType鏄浣曞疄鐜扮殑锛歵ypeFilterType=Pick;澶嶅埗浠g爜鍒嗘瀽棣栧厛锛岃鎴戜滑鐪嬩竴涓嬩唬鐮佷腑鍑虹幇鐨勫嚑绉嶅疄鐢ㄧ▼搴忕被鍨嬨€傦紙鐩存帴璺宠繃锛塱nin鍙互閬嶅巻鏋氫妇绫诲瀷锛岀被浼间簬for...intypeExample='a'|'b'|'c'|'d'typeObj={[绀轰緥涓殑T]:string;//閬嶅巻Example锛屽皢姣忎釜key璧嬪€肩粰string绫诲瀷}/*绛変环浜巘ypeObj={a:string;b锛氬瓧绗︿覆锛沜锛氬瓧绗︿覆锛沝锛氬瓧绗︿覆锛涗綔涓轰竴涓储寮曠被鍨嬬殑鏌ヨ鎿嶄綔绗︼紝鍏跺疄灏辨槸鑾峰彇key鐨勭被鍨嬶紝绫讳技浜嶰bject.keys()锛岃櫧鐒朵笉鐭ラ亾杩欎釜姣斿柣瀵逛笉瀵广€傛帴鍙gず渚媨a:瀛楃涓?b锛氬瓧绗︿覆锛沜锛氭暟閲忥紱d:boolean;}typeKeys=keyofExample//鐩稿綋浜巘ypeKeys='a'|'b'|'c'|'d'鏉′欢鍒ゆ柇interfaceA{a:string;}interfaceBextendsA{b:string;}//B鏄惁缁ф壙鑷狝锛熷鏋滄槸锛屽垯涓虹被鍨嬬紪鍙凤紱濡傛灉涓嶆槸锛屽畠鏄瓧绗︿覆绫诲瀷C=BextendsA?number:string//绛変环浜巘ypeC=number澶嶅埗浠g爜寮€濮嬪垎鏋愬厛鏉ョ湅涓€涓煂帮紝鎻紑濂圭殑闈㈢罕锛屼笉锛屾槸涓€涓帺鐮侊細typeMask={[Kinkeyofsource]:source[K]鎵╁睍绫诲瀷?K:never;}interfaceExample{name:string;height:number}typenewType=Mask//{name:'name';height:never}澶嶅埗浠g爜杩欐椂鍊欐垜浠湅鍒颁竴涓獅name:'name';韬珮锛氫粠涓峿锛屼粈涔堬紵锛燂紵杩欐湁浠€涔堢敤锛熶笉鐢ㄦ媴蹇冿紒鎺ヤ笅鏉ワ紝鎴戜滑缁х画鐪嬩笅闈㈣繖涓緥瀛愶紝鑴变笅濂圭殑澶栬。锛歕鐪嬩竴涓彲浠ヨ鍦ㄧ瑪璁版湰涓婄殑灏忕煡璇嗙偣锛氶珮搴︼細185锛泒[鈥滃鍚嶁€潀"height"]澶嶅埗浠g爜绛夊悓浜庯細typeperson="Angus"|185澶嶅埗浠g爜娉ㄦ剰锛屽綋鍊间负never鏃讹紝灏嗘棤娉曡闂畉ypeperson={name:"Angus";韬珮锛?85锛沢irlFriend锛氫粠涓嶏紱}[鈥滃悕瀛椻€潀鈥滆韩楂樷€潀"girlFriend"]绛夊悓浜庣被鍨媝erson="Angus"|g鐨勮嚜鍢诧紝閭d箞绱㈠紩璁块棶鎺ュ彛灞炴€ф湁浠€涔堢敤鍛紵鐪嬬湅涓嬮潰杩欎釜馃尠鏉ュ睍绀哄ス鐨勮。鏈嶏細typeClothes={[Kinkeyofsource]:source[K]extendstypes?K:never;}[keyofsource]interfaceExample{name:string;楂樺害锛氭暟瀛楋紱home:string}typenewType=Clothes//typenewType="name|home"澶嶅埗浠g爜杩欐牱鎴戜滑灏卞彲浠ュ緱鍒版垜浠兂瑕佺殑绫诲瀷鐨勮仈鍚堢被鍨媆鏈€鍚庝竴姝ワ紝鎴戜滑鎻ずOpen*\hold瀵逛簡锛屾垜浠厛鏉ヤ簡瑙d竴涓婸ick銆俓Pick灏辨槸鍦ㄤ竴涓被鍨嬪璞′腑閫夋嫨鍑犱釜绫诲瀷缁勬垚涓€涓柊鐨勭被鍨嬨€傜晫闈㈠畨鏍兼柉{鍚嶇О锛氬瓧绗︿覆;楂樺害锛氭暟瀛楋紱閲嶉噺锛氭暟瀛楋紱}typenewAngus=Pick//{name:string;height:number}澶嶅埗浠g爜瀹炵幇锛歵ypePick={[PinK]:T[P];}澶嶅埗浠g爜鐒跺悗璁╂垜浠湅鐪嬭胺姝屼笂鐨勯偅涓煂帮細typeFilterType=Pick;闅鹃亾澶嶅埗浠g爜绐佺劧鎵撳紑鍘曟墍锛侊紒锛侀€氳繃Pick锛屾垜浠彲浠ラ€夋嫨鎴戜滑鎯宠鐨勫睘鎬с€倇[KinkeyofSource]:Source[K]extendsTypes?K:never}[keyofSource]澶嶅埗杩欎袱琛屼唬鐮侊紝寰楀埌鎴戜滑鎯宠鐨勫睘鎬с€傚彧闇€鍐嶆閫氳繃Pick鍗冲彲瀹屾垚銆備綘琚睍绀轰簡鍚楋紵涓轰簡鎵╁睍锛岃鎴戜滑鐪嬩竴涓婽S涓殑鍏朵粬涓€浜涘伐鍏风被鍨嬨€侽mitOmit(a,b)鎺ュ彈涓や釜鍙傛暟銆傜涓€涓槸瑕佺紪杈戠殑鍩烘湰绫诲瀷锛岀浜屼釜鏄鍒犻櫎鐨勭被鍨嬨€傜被鍨婸erson={鍚嶇О锛氬瓧绗︿覆锛涙€у埆锛氬瓧绗︿覆锛泒typenewPerson=Omit//{sex:string}澶嶅埗浠g爜鐪嬬湅瀹冩槸濡備綍瀹炵幇鐨勶細typeOmit=Pick>;澶嶅埗浠g爜PartialPartial鍙互蹇€熷皢涓€涓帴鍙g被鍨嬩腑瀹氫箟鐨勫睘鎬ф洿鏀逛负鍙€夛紙Optional锛夌被鍨婸erson={name:string;鎬у埆锛氬瓧绗︿覆锛泒typenewPerson=Partial//{name?:string;sex?:string}澶嶅埗浠g爜鐪嬬湅瀹冩槸濡備綍宸ヤ綔鐨勶細\typePartial={[PinkeyofT]?:T[P]浠g爜Exclude鐢ㄤ簬鍒犻櫎绫诲瀷闆嗗悎涓殑鎸囧畾绫诲瀷銆傝緭鍏=瀛楃涓瞸numbertypenewPerson=Exclude//number澶嶅埗浠g爜瀹炵幇锛歵ypeExclude=TextendsU?never:Tcopy浠g爜Readonly浣挎帴鍙g殑鎵€鏈夊睘鎬у彉涓哄彧璇汇€傜被鍨婸erson={鍚嶇О锛氬瓧绗︿覆锛涙€у埆锛氬瓧绗︿覆锛泒typenewPerson=Readonly//typenewPerson={readonlyname:string;readonlysex:string;}浠g爜瀹炵幇锛歵ypeReadonly={readonly[PinkeyofT]:T[P];}澶嶅埗浠g爜ReturnTypeReturnType鐢ㄤ簬鑾峰彇鍑芥暟T\绫诲瀷鐨勮繑鍥炵被鍨婽0=ReturnType<()=>string>;//瀛楃涓茬被鍨婽1=ReturnType<(s:string)=>void>;//鏃犳晥绫诲瀷T2=ReturnType<()=>T>;//{}绫诲瀷T3=ReturnType<()=>T>;//鏁板瓧[]绫诲瀷T4=ReturnType;//浠讳綍绫诲瀷T5=ReturnType;//浠讳綍绫诲瀷T6=ReturnType;//閿欒绫诲瀷T7=ReturnType;//閿欒澶嶅埗浠g爜瀹炵幇锛歵ypeReturnTypeany>=Textends(...args:any)=>inferR?R锛氫换浣曪紱copycodeParametersParameters鐢ㄤ簬鑾峰彇鍑芥暟T鐨勫弬鏁扮被鍨媡ypegetuserInfo=(user:string)=>void//Parameters鐢ㄤ簬鑾峰彇鍑芥暟T鐨勫弬鏁扮被鍨媡ypeParametersUserInfo=Parameters杩欓噷鍏堜粙缁嶅鍒朵唬鐮併€傛垜鐜板湪澶у洓浜嗭紝鏄庡勾鍘荤綉鏄撴惉鐮栥€傜粨璇垜鏄灄涓夐懌锛屼竴涓媯鐑殑鍓嶇鑿滈笩绋嬪簭鍛樸€傚鏋滀綘鏈変笂杩涘績锛屽枩娆㈠墠绔紝鎯冲鍓嶇锛岄偅鎴戜滑鍙互浜や釜鏈嬪弸锛屼竴璧烽挀楸煎搱鍝堬紝鎽告懜楸肩兢锛屽姞鎴戯紝璇锋敞鎰廩鎬濇兂]