面试官:连Vue3响应式系统都不会写,还敢说精通?
时间:2023-03-28 16:25:01
HTML
涔熻浣犳垜绱犳湭璋嬮潰锛屼絾寰堟湁鍙兘鎴戜滑浼氱浉瑙佹櫄銆傛垜鏄墠绔偉澶撮奔銆傚墠瑷€璇翠粖骞存槸宸ヤ綔鏈€宸殑涓€骞淬€傚ぇ鍘傝鍛橈紝灏忓巶璺熼锛屾姇鍑哄嚑鐧句唤绠€鍘嗗苟鍥炲鐨勫瀵ユ棤鍑犮€備笁閲戝洓閾跺ぇ姒傚彉鎴愪簡涓夐摐鍥涢搧锛屽噭鍑夊噭鍑夛紝鍑勫噳鍑勬儴銆傝€屼粖澶╃殑涓昏锛屽皬甯呭悓瀛︼紝鍗村湪閫嗛鐨勭幆澧冧笅缁欎簡闈㈣瘯瀹樹竴涓闈㈢殑鎵撳嚮锛屽ぇ绉€涓€韬紝浼樼濡備粬锛屽埌搴曠粡鍘嗕簡鎬庢牱鐨勯潰璇曪紵鏂囩珷涓殑渚嬪瓙鍜屼唬鐮佸彲浠ョ偣鍑昏繖閲屾煡鐪嬨€?.#鍑洪闈㈣瘯瀹橈細鎴戠湅浣犵殑绠€鍘嗘槸绮鹃€歏ue3骞朵笖鐮旂┒杩囧畠鐨勬簮鐮侊紵骞磋交浜虹柉浜嗭紒鎴戜滑鐜板満琛ㄦ紨鎬庝箞鏍凤紵姣曠珶闈㈣瘯瀹樼幇鍦哄嚭棰樹簡...
灏忓竻鏆楀枩馃構锛氳繖涓畝鍗曪紝灏辨槸鎴彇鐘舵€佸璞★紝鍦ㄥ彇鏂囨湰鍊肩殑鏃跺€欐敹闆嗘晥鏋滃嚱鏁颁緷璧栵紝鐒跺悗鍦ㄥ彇鍊肩殑鏃跺€欐墽琛屼竴娉㈡敹闆嗗埌鐨勬晥鏋滃嚱鏁拌缃枃鏈殑鍊笺€傞潰璇曞畼锛氬搸锛屾垜涔熻锛屽埆閫兼垜锛屽揩鍐欏惂...2Version1:璺戣捣鏉ヤ簡锛屼笉杩囪繕涓嶉€氱敤锛宲awn2.1#婧愮爜瀹炵幇灏忓竻寰堝揩灏卞啓濂戒簡绗竴涓増鏈紝鏍稿績鍦ㄩ偅閲屽彧鏈変袱姝ワ細绗竴姝ワ細鏀堕泦渚濊禆锛堟晥鏋滃嚱鏁帮級锛岃鍙杒ey鏃跺瓨鍌ㄦ晥鏋滃嚱鏁扮浜屾锛氳缃€兼椂锛屾墽琛屼緷璧栵紙鏁堟灉鍑芥暟锛塩onst$app=document.querySelector('#app')constbucket=newSet()conststate=newProxy({text:'hellofatfish'},{get(target,key){constvalue=target[key]//绗竴姝ワ細鏀堕泦渚濊禆锛岃鍙栨椂閿紝瀛樺偍鏁堟灉functionbucket.add(effect)console.log(`get${key}:${value}`)returnvalue},set(target,key,newValue){console.log(`set${key}:${newValue}`)target[key]=newValue//Step2:璁剧疆鍊兼椂锛屼細渚濊禆鎵цbucket.forEach((fn)=>fn())}})functioneffect(){console.log('鎵ц鏁堟灉')$app.innerText=state.text}effect()setTimeout(()=>{state.text='helloVue3'},1000)鏁堟灉棰勮鐐瑰嚮棰勮锛屽搾鍝掑搾锛岀湅璧锋潵寰堢畝鍗曪紝鐬棿鎼炲畾锛?.2#闈㈣瘯瀹樿瘎浠烽潰璇曞畼锛氬姛鑳藉疄鐜颁簡锛屼絾鏄笉鏄緢婊℃剰銆備綘杩欓噷鐨勯泦鍚堜緷璧栨槸涓€涓‖缂栫爜鐨勫嚱鏁板悕鏁堟灉锛屽彧瑕佺◢绋嶆崲涓瘽棰樺氨涓嶈浜嗐€?divid="container">