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

【JavaScriptWeekly#554】ES2022feature-Classstaticinitializationblock

时间:2023-03-29 11:11:59 HTML

馃コ娆㈣繋鏈夊叴瓒g殑灏忎紮浼翠竴璧锋潵鍋氱偣鏈夋剰涔夌殑浜嬫儏锛佹湰鏂囪瘧鑰咃細NaturalVolume鎴戞帹鍑轰簡涓€涓瘡鍛ㄧ炕璇戦」鐩紝浠撳簱鍦板潃锛岃闂湴鍧€杩樻槸寰堢己蹇楀悓閬撳悎鐨勬湅鍙嬶紝绾睘涓汉鍏磋叮锛屽綋鐒朵篃鏈夊姪浜庢彁楂樿嫳璇拰鍓嶇鎶€鑳斤紝瑕佹眰锛氳嫳鏂囪繕涓嶉敊铔í鐨勶紝鐔熺粌浣跨敤github锛屾湁姣呭姏锛岃唉铏氾紝鍋氫簨璐熻矗銆傛兂鍙備笌鐨勬湅鍙嬪彲浠ョ淇x锛屾垨鑰呯粰浠撳簱鍙慽ssue娑堟伅銆傛垜鐨勫崥瀹㈣繕鏈夊叿浣撶殑涓汉鑱旂郴鏂瑰紡锛歞aodaolee.cnRonBuckton鐨凟CMAScript鎻愭鈥滅被闈欐€佸垵濮嬪寲鍧椻€濆湪绗?闃舵锛岃鍒掓敹褰曞埌ECMAScript2022涓€備负浜嗗垱寤轰竴涓被鐨勫疄渚嬶紝鎴戜滑鍦↗avaScript涓湁涓や釜缁撴瀯锛欶ield锛氬垱寤猴紙骞跺彲閫夊湴鍒濆鍖栵級瀹炰緥灞炴€с€傛瀯閫犲嚱鏁帮細鍦ㄨ缃畬鎴愪箣鍓嶆墽琛岀殑浠g爜鍧楄璁剧疆绫荤殑闈欐€侀儴鍒嗭紝鎴戜滑鍙湁闈欐€佸瓧娈点€侲CMAScript寤鸿涓虹被寮曞叆浜嗛潤鎬佸垵濮嬪寲鍧楋紝瀹冧滑瀵归潤鎬佺被鐨勪綔鐢ㄥぇ鑷翠笌鏋勯€犲嚱鏁板瀹炰緥鐨勪綔鐢ㄧ浉鍚屻€?涓轰粈涔堟垜浠湪绫讳腑浣跨敤闈欐€佸潡锛熷綋鎴戜滑璁剧疆闈欐€佸瓧娈垫椂锛屼娇鐢ㄥ閮ㄥ嚱鏁伴€氬父鏁堟灉寰堝ソ锛歴taticenglishWords=extractEnglish(this.translations);staticgermanWords=extractGerman(this.translations);}functionextractEnglish(translations){returnObject.keys(translations);}functionextractGerman(translations){returnObject.values(translations);}浣跨敤澶栭儴鍑芥暟娌℃湁閿檈xtractEnglish()鍜宔xtractGerman()鍥犱负鎴戜滑鍙互鐪嬪埌瀹冧滑鏄粠绫诲唴閮ㄨ皟鐢ㄧ殑锛屽苟涓斿畠浠畬鍏ㄧ嫭绔嬩簬绫汇€備絾鏄鏋滄垜浠鍚屾椂璁剧疆涓や釜闈欐€佸瓧娈碉紝灏变細鏈夌偣濂囨€細classTranslator{statictranslations={yes:'ja',no:'nein',maybe:'vielleicht',};闈欐€佽嫳璇崟璇?[];闈欐€乬ermanWords=[];static_=initializeTranslator(//(A)this.translations,this.englishWords,this.germanWords);}functioninitializeTranslator(translations,englishWords,germanWords){for(const[english,german]ofObject.entries(translations))}{englishWords.push(鑻辫);germanWords.push锛堝痉璇級锛泒}杩欐牱鍐欐湁涓や釜闂锛氱被鍒涘缓鍚庡繀椤诲湪绫诲棰濆璋冪敤initializeTranslator()銆傛垨鑰呭湪A澶勬墽琛屻€倀ranslator鐨勭鏈夋暟鎹棤娉曡闂甶nitializeTranslator()銆傚鏋滀綘浣跨敤闈欐€佸潡A锛屼綘鍙互杩欐牱鍐欙細classTranslator{statictranslations={yes:'ja',no:'nein',maybe:'vielleicht',};闈欐€佽嫳璇崟璇?[];闈欐€乬ermanWords=[];static{//(A)for(const[english,german]ofObject.entries(this.translations)){this.englishWords.push(english);this.germanWords.push锛堝痉璇級锛泒}}2鏇村鏉傜殑绀轰緥鍦↗avaScript涓疄鐜版灇涓剧殑涓€绉嶆柟娉曟槸閫氳繃Enum瓒呯被锛堟湁鍏宠缁嗕俊鎭紝璇峰弬闃呭簱enumify锛塩lassEnum{staticcollectStaticFields(){//闈欐€佹柟娉曚笉鍙灇涓撅紝鍥犳灏嗚蹇界暐this.enumKeys=Object.keys(杩欎釜);}}classColorEnumextendsEnum{staticred=Symbol('red');staticgreen=Symbol('缁胯壊');staticblue=Symbol('钃濊壊');static_=this.collectStaticFields();//(A)staticlogColors(){for(constenumKeyofthis.enumKeys){//(B)console.log(enumKey);}}}ColorEnum.logColors();//Output://'red'//'green'//'blue'闈欐€佸瓧娈甸渶瑕佸湪杩欓噷鏀堕泦锛岃繖鏍锋垜浠氨鍙互杩唬鏋氫妇椤圭殑閿€硷紙B琛岋級銆傛墍鏈夐潤鎬佸瓧娈电殑鍒涘缓鍒版缁撴潫銆傜劧鍚庢垜浠啀娆¤皟鐢ˋ琛岀殑浠g爜锛岃繖鏍锋瘮杈冧紭闆呫€?缁嗚妭鐩稿鑰岃█锛岄潤鎬佸潡鐨勭粏鑺傛槸绗﹀悎閫昏緫鐨勶紙鐩稿浜庡疄渚嬫垚鍛樼瓑鏇村鏉傜殑瑙勫垯锛夛細姣忎釜绫诲彲浠ユ湁澶氫釜闈欐€佸潡銆傞潤鎬佸潡涓庨潤鎬佸瓧娈靛垵濮嬪寲浜ょ粐鍦ㄤ竴璧枫€傝秴绫荤殑闈欐€佹垚鍛樺湪瀛愮被鐨勯潤鎬佹垚鍛樹箣鍓嶆墽琛屻€備互涓嬩唬鐮佹紨绀轰簡杩欎簺瑙勫垯锛歝lassSuperClass{staticsuperField1=console.log('superField1');static{assert.equal(this,SuperClass);console.log('staticblock1SuperClass');}staticsuperField2=console.log('superField2');static{console.log('staticblock2SuperClass');}}classSubClassextendsSuperClass{staticsubField1=console.log('subField1');static{assert.equal(this,SubClass);console.log('staticblock1SubClass');}staticsubField2=console.log('subField2');static{console.log('staticblock2SubClass');}}//Output://'superField1'//'staticblock1SuperClass'//'superField2'//'staticblock2SuperClass'//'subField1'//'staticblock1SubClass'//'subField2'//'staticblock2SubClass'4鏀寔绫婚潤鎬佸潡鐨勫伐鍏稸8:鏈湪v9.4.146涓爣璁?source)SpiderMonkey:宸插湪v92涓爣璁帮紝v93鏈爣璁皊ource)TypeScript:v4.4(source)5JavaScript鏄惁鎴愪负瓒婃潵瓒婂枩娆ava杩樻槸鍙樹贡锛熻繖鏄竴涓笉涓庡叾浠栧姛鑳藉啿绐佺殑灏忓姛鑳斤紝鎴戜滑宸茬粡鍙互閫氳繃甯︽湁static_=...瀛楁鐨勫伐浣滃尯杩愯闈欐€佷唬鐮併€傞潤鎬佸潡鎰忓懗鐫€涓嶅啀闇€瑕佹宸ヤ綔绌洪棿銆傞櫎姝や箣澶栵紝绫诲彧鏄疛avaScript绋嬪簭鍛樻嫢鏈夌殑浼楀宸ュ叿涔嬩竴銆傛垜浠彲浠ョ敤涔熷彲浠ヤ笉鐢紝杩樻湁寰堝鍏朵粬鐨勯€夋嫨銆?缁撹绫婚潤鎬佸潡鏄竴涓浉瀵圭畝鍗曠殑鐗规€э紝瀹冨畬鍠勪簡绫婚潤鎬佺壒鎬с€傜矖鐣ュ湴璇达紝瀹冩槸瀹炰緥鏋勯€犲嚱鏁扮殑闈欐€佺増鏈€傚綋鎴戜滑蹇呴』璁剧疆澶氫釜闈欐€佸瓧娈垫椂锛屽畠闈炲父鏈夌敤銆傜浉鍏抽摼鎺ュ師鏂囬摼鎺ョ炕璇戠▼搴忓師鏂?/p>

最新推荐
猜你喜欢