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

前端技术双周刊2023-03-25:加速JavaScript生态

时间:2023-03-28 15:28:13 HTML

椤圭洰鍦板潃锛歰livewind/鍛ㄥ垔寰俊鍏紬鍙凤細渚濊禆娉ㄥ叆鍙戝竷鏃ユ湡锛?023.03.25鏈懆鍐呭锛氳祫璁痻3锛屽紑婧恱9锛屾枃绔爔3琛屼笟璧勮鏂扮増React瀹樼綉鎷ユ湁鍏ㄦ柊鐨勫煙鍚嶅拰UI锛氭柊鐗堝煙鍚嶄负https://react.dev锛屾棫鐗堟枃妗e皢涓嶅啀鏇存柊瀛樻。鍦╤ttps:///legacy.reactjs.org鏇翠赴瀵岀殑浜や簰demo锛氬紩鍏ュ浘琛ㄣ€佹彃鍥惧姞娣卞嵃璞★紝缁存姢600澶氫釜渚嬪瓙锛屼唬鐮佹敮鎸佸嚱鏁扮粍浠跺拰Hooks鐨勪氦浜掍娇鐢細鎰忓懗鐫€鏂板悓瀛︿笉鍐嶉渶瑕佷粠绫荤粍浠朵腑瀛︿範鍜屼互鍓嶄竴鏍凤紝鍗充娇浣犲嚑涔庝笉鍐嶄娇鐢ㄧ被缁勪欢鏂扮殑鍜岃缁嗙殑API鏂囨。锛氬寘鎷琑eference銆乁sage鍜孴roubleshooting锛屽苟鎻愪緵涓€浜涘父瑙侀棶棰樼殑瀹樻柟绛旀瀹樻柟缃戠珯涓婄殑宸ヤ綔閲嶇偣on锛氭彁渚涙墍鏈夌ず渚嬬殑TypeScript鐗堟湰锛涘垱寤烘洿鏂扮殑鎬ц兘銆佹祴璇曞拰鍙闂€ф寚鍗楋紱鐙珛浜庢敮鎸佸畠浠殑妗嗘灦璁板綍React鏈嶅姟鍣ㄧ粍浠讹紱涓庢垜浠殑鍥介檯绀句細鍚堜綔缈昏瘧鏂版枃浠讹紱娣诲姞缂哄皯鐨勫姛鑳斤紙渚嬪锛屾鍗氬鐨凴SS锛夈€侲lectron10骞答煄夌粡杩?0骞村拰鏉ヨ嚜1,192鍚嶈础鐚€呯殑27,147娆℃彁浜わ紝Electron鏄綋浠婃渶娴佽鐨勬瀯寤烘闈㈠簲鐢ㄧ▼搴忕殑妗嗘灦涔嬩竴锛屽畼鏂瑰洟闃熸渶杩戝彂甯冧簡涓€绡囧簡绁濆笘瀛愶紝骞舵杩颁簡浠栦滑濡備綍杩愪綔涓€涓彲鎸佺画鐨勫ぇ瑙勬ā寮€婧愰」鐩富瑕佹湁浠ヤ笅鍑犵偣锛氳璁℃敮鎸佸洟闃熸墿灞曠殑娌荤悊妯″瀷锛氫笉鍚岀殑宸ヤ綔缁勬湁涓嶅悓鐨勮亴璐o紝杩欏浜庣畝鍖栨祦绋嬪拰灏嗛」鐩墍鏈夋潈鍒嗛厤缁欑壒瀹氱殑缁存姢鑰呴潪甯搁噸瑕併€傛湁杩欎簺宸ヤ綔缁勶紙WG锛夛細ReleasesWG锛氳礋璐e彂甯僂lectron鍦ㄧ嚎鍗囩骇WG锛氳礋璐e崌绾hromium鍜孨ode.jsAPIWG锛氳礋璐g洃鐫e紑鏀続PI璁捐SecurityWG锛氳礋璐g淮鎶lectron鐢熸€佺郴缁熺殑瀹夊叏WG锛氳礋璐g敤浜庤繍钀ョ綉绔欍€佹枃妗e拰宸ュ叿OutreachWG锛氳礋璐gぞ鍖哄拰浼佷笟澶栧睍Community&SafetyWG锛氳礋璐gぞ鍖虹鐞咺nfrastructureWG锛氳礋璐g淮鎶ゅ拰寤鸿鍩虹璁炬柦銆佷簯鏈嶅姟寤鸿浠ュ強鍙備笌绀惧尯浠ユ彁楂樼煡鍚嶅害2020骞达紝Discord绀惧尯鎺ㄥ嚭2021骞达紝ElectronChina鎴愮珛鐢ㄦ埛缇ゅ弬涓庨珮璋冪ぞ鍖烘椿鍔ㄥ拰寮€婧愰」鐩嚜2019骞翠互鏉ユ瘡骞村簡绁滺acktoberest锛堢敱DigitalOcean缁勭粐鐨勫勾搴﹀紑婧愬簡鍏革級2020骞达紝鍙傚姞鏈夊彶浠ユ潵绗竴涓狦oogleSeasonofDocs娲诲姩2022骞达紝棣栨鎸囧瀛︾敓GoogleSummerofCode鑷姩鍖栦竴鍒囦互鎻愰珮鏁堢巼TypeScript5.0姝e紡鍙戝竷姝ょ増鏈富瑕佸寘鎷互涓嬫洿鏂帮細鏂扮殑瑁呴グ鍣細鏃犻渶鏄剧ず鏍囪瀹為獙瑁呴グ鍣ㄥ彲浠ヤ娇鐢ㄨ楗板櫒const绫诲瀷鍙傛暟锛岃繖鎰忓懗鐫€浣犲湪涓嬮潰杩欑鎯呭喌涓嬪畠涓嶅啀闇€瑕佷娇鐢╝sconst//鍦?.0涔嬪墠typeHasNames={readonlynames:string[]};functiongetNamesExactly(arg:T):T["names"]{returnarg.names;}//鎺ㄦ柇绫诲瀷锛歴tring[]constnames=getNamesExactly({names:["Alice","Bob","Eve"]});//鎺ㄦ柇绫诲瀷锛氬彧璇籟"Alice","Bob","Eve"]constnames=getNamesExactly({names:["Alice","Bob","Eve"]asconst});----//5.0寮€濮嬬被鍨婬asNames={names:readonlystring[]};functiongetNamesExactly(arg:T):T["names"]{//^^^^^returnarg.names;}//鎺ㄦ柇绫诲瀷锛氬彧璇籟"Alice","Bob","Eve"]constnames=getNamesExactly({names:["Alice","Bob","Eve"]});extends鏀寔澶氫釜閰嶇疆鏂囦欢{"extends":["a","b","c"],"compilerOptions":{//...}}鎵€鏈夋灇涓鹃兘鏄仈鍚堟灇涓撅細杩欐剰鍛崇潃鍗充娇鏋氫妇鍊兼槸鍑芥暟璋冪敤锛屽彲浠ュ紩鐢ㄦ灇涓剧被鍨嬬殑瀛愰泦enumColor{Red,Orange,Yellow=Math.random()}//5.0涔嬪墠鎶ラ敊锛氣€滄灇涓剧被鍨嬧€滳olor鈥濆寘鍚竴涓垚鍛榳ith涓嶆槸鏂囨湰鐨勫垵濮嬪€艰瀹氶」鈥濈被鍨婱yColor=Color.Red|棰滆壊涓烘鑹?鏀寔瀵煎嚭绫诲瀷*鏀寔customConditions濡傛灉妯″潡package.json鑷畾涔変簡鍔犺浇鍏ュ彛{//..."exports":{"my-condition":"./foo.mjs","node":"./bar.mjs","import":"./baz.mjs","require":"./biz.mjs"}}姝ゆ椂浣犲彲浠ヤ娇鐢╟ustomConditions瑕佹眰TypeScript浠巉oo.mjs鍔犺浇妯″潡浣滀负鍏ュ彛{"compilerOptions":{"target":"es2022","moduleResolution":"bundler","customConditions":["my-condition"]}}鏈増鏈墍鏈夋洿鏂拌鍙傝€冿細瀹e竷TypeScript5.0寮€婧愰」鐩甈lexPt/awesome-chatgpt-prompts-zh(21kstars)ChatGPT鏄敱OpenAI璁粌鐨勫ぇ鍨嬭瑷€妯″瀷锛岄€氳繃缁欏畠鎻愮ず锛屽畠鍙互鐢熸垚缁х画瀵硅瘽鎴栨墿灞曠粰瀹氭彁绀虹殑鍝嶅簲鍦ㄨ繖涓」鐩腑浣犱細鍙戠幇鍚勭鎻愮ず锛屼綘鍙互浣跨敤浣跨敤ChatGPT甯姪鎮ㄤ簡瑙e浣曚娇鐢–hatGPT銆倀remorlabs/tremor(7.1kstars)Tremor鎻愪緵浜嗕竴绯诲垪涓撴敞浜庝华琛ㄦ澘鏋勫缓鐨勭粍浠讹紝骞舵彁渚涗簡涓嶅悓鍦烘櫙涓嬬殑鏈€浣冲疄璺典緵鍙傝€冿紝鍙互甯姪鎮ㄨ交鏉炬瀯寤烘湁娲炲療鍔涚殑浠〃鏉裤€傛湰椤圭洰鍩轰簬React銆乀ailwind銆丷echarts鏋勫缓銆俧ramer/motion(18kstars)Motion鏄竴涓畝鍗曚絾鍔熻兘寮哄ぇ鐨凴eact鍔ㄧ敾搴擄紝瀹冧娇甯歌鐨勫姩鐢婚潪甯稿鏄撳疄鐜般€俶ozilla/source-map(3.2kstars)source-map鏄疢ozilla鍥㈤槦寮€婧愮殑涓€涓彲浠ユ璐熻В鍐砈ourceMap鐨勫伐鍏峰簱锛屽彲鑳藉JavaScript鐩稿叧鐩戞帶绯荤粺鐨勫疄鐜版湁鐢ㄣ€傚鏋滀笉鐔熸倝SourceMap鐨勫師鐞嗭紝鍙互鍙傝€僑ourceMap鐨勭涓夌増鎻愭銆俢onstrawSourceMap={version:3,file:"min.js",names:["bar","baz","n"],sources:["one.js","two.js"],sourceRoot:鈥渉ttp://example.com/www/js/鈥濓紝鏄犲皠锛氣€淐AAC銆両AAI銆両AAM銆丼AAUA銆丟AClB銆丱AAOC銆両AAID锛汣CDb銆両AAI銆両AAM銆丼AAUE銆丟AClB銆丱AAOA鈥濓紝}锛沜onstwhatever=awaitSourceMapConsumer.with(rawSourceMap,null,consumer=>{console.log(consumer.sources);//['http://example.com/www/js/one.js',//'http://example.com/www/js/two.js']console.log(consumer.originalPositionFor({line:2,column:28,}));//{source:'http://example.com/www/js/two.js',//line:2,//column:10,//name:'n'}console.log(consumer.generatedPositionFor({source:"http://example.com/www/js/two.js",line:2,column:10,}));//{line:2,column:28}consumer.eachMapping(function(m){//...});杩斿洖璁$畻eWhatever();});lovell/sharp(24.8kstars)鍩轰簬libvips搴撶殑楂樻€ц兘鏄撶敤鐨凬ode.js鍥惧儚澶勭悊宸ュ叿锛屽彲鐢ㄤ簬璋冩暣JPEG銆丳NG銆乄ebP銆丄VIF鍜孴IFFimagesduringconversion瀹冨彲鑳藉湪鍥惧儚鍜屾坊鍔犳按鍗扮瓑鍦烘櫙涓緢鏈夌敤銆俿harp('input.jpg').rotate().resize(200).jpeg({mozjpeg:true}).toBuffer().then(data=>{...}).catch(err=>{...});dolanmiu/docx锛?kstars锛塪ocx鏄竴涓敮鎸侀€氳繃澹版槑寮廇PI鍦↗S/Node涓嬭交鏉剧敓鎴愬拰淇敼.docx鏂囦欢鐨勫伐鍏峰簱銆俧unctiongenerate(){constdoc=newdocx.Document({sections:[{properties:{},children:[newdocx.Paragraph({children:[newdocx.TextRun("HelloWorld"),newdocx.TextRun({text:"FooBar",bold:true}),newdocx.TextRun({text:"\tGithubisthebest",bold:true})]})]}]});docx.Packer.toBlob(doc).then((blob)=>{console.log(blob);saveAs(blob,"example.docx");console.log("鏂囨。鍒涘缓鎴愬姛");});}probablyup/markdown-to-jsx(1.5kstars)markdown-to-jsx鏄竴涓交閲忕骇銆佸彲鑷畾涔夌殑Reactmarkdown缁勪欢锛屼娇鐢ㄩ潪甯哥畝鍗曪紝鑺傜偣娓叉煋鍙互鏍规嵁闇€瑕侀噸鍐欐垨鏇挎崲銆俰mportMarkdownfrom'markdown-to-jsx';importReactfrom'react';import{render}from'react-dom';//鎯婂枩锛屽畠鏄竴涓猟iv锛乧onstMyParagraph=({children,...props})=>({children}

);render(#Helloworld!,document.body);/*娓叉煋锛?divclass="foo">HelloWorld
*/DioxusLabs/dioxus锛?.9k棰楁槦锛塂ioxus鏄竴绉嶄究鎼哄紡銆侀珮鎬ц兘銆佺鍚堜汉浣撳伐绋嬪鐨勬鏋讹紝鐢ㄤ簬浣跨敤Rust璇█鏋勫缓璺ㄥ钩鍙扮敤鎴风晫闈€傚鏋滀綘鐔熸倝React妗嗘灦锛孌ioxus瀵逛綘鏉ヨ浼氬緢瀹规槗銆俧napp(cx:Scope)->Element{letmutcount=use_state(cx,||0);cx銆傛覆鏌擄紙rsx锛亄h1{鈥滈珮浜旇鏁板櫒锛歿count}鈥潁鎸夐挳{onclick锛氱Щ鍔▅_|璁℃暟+=1锛屸€滈珮锛佲€潁鎸夐挳{onclick锛氱Щ鍔▅_|璁℃暟-=1锛屸€滀綆璋冿紒鈥潁})}slidevjs/slidev锛?5.8k鏄燂級Slidev鏄竴涓熀浜庣綉缁滅殑骞荤伅鐗囧垱浣滃拰婕旂ず宸ュ叿銆傚畠鏃ㄥ湪璁╁紑鍙戜汉鍛樹笓娉ㄤ簬鐢∕arkdown缂栧啓鍐呭锛屽悓鏃跺叿鏈夋敮鎸丠TML鍜孷ue缁勪欢鐨勮兘鍔涳紝骞朵笖鍙互鍛堢幇鍍忕礌瀹岀編鐨勫竷灞€锛屽苟涓旇繕鍦ㄦ偍鐨勬紨绀烘枃绋夸腑鍐呯疆浜嗕氦浜掑紡婕旂ず绀轰緥銆備紭璐ㄦ枃绔燗ccelerationtheJavaScriptEcosystem(English)鏈郴鍒椾粙缁嶅父鐢ㄥ伐鍏峰寘鎷琾ostcss銆乻vgo銆乪slint銆乶pmscripts绛夌殑鎬ц兘闂鍜屼紭鍖栨柟娉曪紝鐪嬪畬瑙夊緱鈥滅埥鈥濄€傚浣曞湪2023骞村紑濮嬩竴涓猂eact椤圭洰锛燂紙鑻辨枃锛夋湰鏂囪缁嗕粙缁嶄簡浣跨敤Vite銆丯ext鍜孉stro鏋勫缓React搴旂敤绋嬪簭鐨勪紭缂虹偣锛屼互鍙奟eact瀹樻柟锛堜笉锛夋帹鑽愬畠浠殑鍘熷洜銆備綘鐪熺殑浜嗚ВsetTimeout鍚楋紵璋堣皥setTimeout鐨勬渶灏忓欢鏃堕棶棰樺父鐢ㄧ殑setTimeout鍑芥暟鍦ㄤ笉鍚岀殑JavaScript杩愯鏃舵湁涓嶅悓鐨勫疄鐜帮紝鎵ц鏁堟灉涔熶笉鍚岋紱鏈枃缁撳悎浜哻hromium銆乶odejs銆乨eno銆乥un绛夋祦琛岀殑JS杩愯鏃舵簮浠g爜锛岃缁嗗垎鏋愪簡杩欎簺宸紓銆傛湰鏂囩敱mdnice澶氬钩鍙板彂甯?/p>