移动端开发:Vue中正确修改数组触发视图回显
鏈夋病鏈夐亣鍒拌繃鍦ㄦ墜鏈轰笂婊戝姩鍒楄〃锛屾暟鎹娲讳笉鏇存柊鐨勬儏鍐碉紵鎵嬫寚澶撮兘蹇妸灞忓箷鎼撳嚭鐏槦瀛愪簡锛岄〉闈㈣繕鏄汗涓濅笉鍔紵浠婂ぉ鍜变滑灏辨潵鎺版壇鎺版壇杩欎釜璁╃Щ鍔ㄧ寮€鍙戝ご绉冪殑缁忓吀闂銆?/p>
涓€銆佺Щ鍔ㄧ涓哄暐鏇村鏄撹俯鍧戯紵馃摫
鍏堣涓湡瀹炴渚嬶細涓婂懆鏈変釜瀛﹀憳鍋歍ODO鍒楄〃搴旂敤锛屽湪鐢佃剳涓婃祴璇曞ソ濂界殑锛岀粨鏋滅敤鎵嬫満鎵撳紑鈥斺€斿畬鎴愪簨椤瑰嬀閫夊悗姝绘椿涓嶅埛鏂帮紒鎬ュ緱浠栧樊鐐规妸鎵嬫満鎵旀按閲屻€備綘鐚滈棶棰樺嚭鍦ㄥ摢锛熲€?strong>鈥嬬Щ鍔ㄧ瑙︽帶浜嬩欢鍜屽搷搴斿紡鏇存柊浜х敓浜嗗濡欏寲瀛﹀弽搴斺€?/strong>鈥嬨€?/p>
杩欓噷瑕佹暡榛戞澘浜嗭細绉诲姩绔紑鍙戞湁涓変釜鐗规畩鐐癸細
- 鈥?strong>鈥嬫墜鍔挎搷浣滈绻佲€?/strong>鈥嬶紙婊戝姩/闀挎寜/鎷栨嫿锛?/li>
- 鈥?strong>鈥嬫€ц兘瑕佹眰鏇撮珮鈥?/strong>鈥嬶紙鍐呭瓨鍚冪揣锛?/li>
- 鈥?strong>鈥嬬綉缁滅幆澧冨鏉傗€?/strong>鈥嬶紙寮辩綉缂撳瓨鏈哄埗锛?/li>
涓句釜馃尠锛氬綋浣犵敤vue鍋氫笅鎷夊埛鏂版椂锛岀洿鎺ョ粰鏁扮粍push鏂版暟鎹彲鑳戒笉鐢熸晥銆備负鍟ワ紵鍥犱负绉诲姩绔粡甯哥敤绗笁鏂规墜鍔垮簱锛屽畠浠細鍔寔鍘熺敓浜嬩欢锛屾墦涔眝ue鐨勬洿鏂拌妭濂忋€?/p>
浜屻€佷簲澶у繀鏉€鎶€瀹炴祴瀵规瘮 馃挭
鎷涘紡1锛氬彉寮傛柟娉曞叏瀹舵《 馃О
vue瀹樻柟閽﹀畾鐨?澶ф硶瀹濆繀椤荤墷璁帮細
push()
// 鏈熬鍔犳枡pop()
// 骞叉帀鏈€鍚庝竴浣?/li>shift()
// 绉婚櫎棣栭」unshift()
// 寮€澶存彃闃?/li>splice()
// 涓囪兘鎵嬫湳鍒€sort()
// 閲嶆柊鎺掗槦reverse()
// 鍊掕溅璇锋敞鎰?/li>
瀹炴祴鍦烘櫙锛氱Щ鍔ㄧ甯歌鐨勫乏婊戝垹闄?/p>
javascript澶嶅埗// 閿欒绀鸿寖锛堥〉闈㈣姝伙級 this.items[index] = null // 姝g‘濮垮娍锛堜笣婊戞洿鏂帮級 this.items.splice(index, 1)
鈿狅笍娉ㄦ剰锛氬湪閮ㄥ垎瀹夊崜鏈轰笂锛宻plice鍙兘寮曞彂鍒楄〃闂姩锛岃繖鏃跺€欓渶瑕侀厤鍚?code>
鎷涘紡2锛?set澶ф硶濂?鉁?/h4>
閬囧埌蹇呴』鐢ㄧ储寮曟搷浣滄椂锛屾帍鍑鸿繖涓潃鎵嬮攺锛?/p>
javascript澶嶅埗this.$set(this.list, index, newValue)
杩欎釜鏂规硶鐨勫澶勫氨鍍忕粰鎵嬫満璐撮槻绐ヨ啘鈥斺€旀棦鏀逛簡鏁版嵁锛屽張淇濊瘉瑙嗗浘鍚屾鏇存柊銆備絾鏈変釜鍧戣娉ㄦ剰锛氣€?strong>鈥嬪湪绉诲姩绔暱鍒楄〃涓娇鐢ㄦ椂锛岄绻佽皟鐢ㄥ彲鑳藉崱椤库€?/strong>鈥嬨€?/p>
鎷涘紡3锛氭暟缁勬暣瀹规湳 馃寑
杩欐嫑閫傚悎涓嬫媺鍒锋柊鍦烘櫙锛?/p>
javascript澶嶅埗this.list = [...this.list].filter(item => !item.completed)
鐩稿綋浜庣粰鏁扮粍鎹釜椹敳锛屽己鍒惰Е鍙戞洿鏂般€備絾瑕佹敞鎰忥紒鈥?strong>鈥嬪湪浣庨厤瀹夊崜鏈轰笂锛屽ぇ鏁扮粍鎿嶄綔鍙兘寮曞彂椤甸潰鍋囨鈥?/strong>鈥嬶紝寤鸿閰嶅悎楠ㄦ灦灞忎娇鐢ㄣ€?/p>
鎷涘紡4锛氬璞″厠闅嗘祦 馃
澶勭悊瀵硅薄鏁扮粍鏃剁殑淇濆懡鎶€宸э細
javascript澶嶅埗const newItem = { ...this.list[index], status: 'done' } this.list.splice(index, 1, newItem)
杩欐嫑鍦ㄧЩ鍔ㄧ鍟嗗搧璇︽儏椤电壒鍒鐢紝姣斿淇敼瑙勬牸閫夋嫨鏃讹紝鑳戒繚璇佽鍥惧強鏃跺洖鏄俱€?/p>
鎷涘紡5锛歳ef鍘熷瓙寮癸紙Vue3涓撳睘锛?馃挘
Vue3鐢ㄦ埛璇曡瘯杩欎釜鏂板Э鍔匡細
javascript澶嶅埗import { ref } from 'vue' const list = ref([]) // 涓嬫媺鍔犺浇鏇村绀轰緥 const loadMore = () => { fetchData().then(res => { list.value = [...list.value, ...res.data] }) }
杩欎釜.value
鍒氬紑濮嬬敤鍙兘瑙夊緱鍙嶄汉绫伙紝浣嗕範鎯簡浼氬彂鐜扮湡棣欙紒鐗瑰埆鏄湪绉诲姩绔垎椤靛姞杞芥椂锛屾祦鐣呭害鎻愬崌鑲夌溂鍙銆?/p>
涓夈€佹柟妗堥€夋嫨鎸囧崡 馃摑
鏂规硶 | 閫傜敤鍦烘櫙 | 绉诲姩绔€傞厤搴?/th> | 鎬ц兘娑堣€?/th> |
---|---|---|---|
鍙樺紓鏂规硶 | 甯歌鎿嶄綔 | 猸愨瓙猸愨瓙 | 猸愨瓙 |
$set | 绮惧噯瀹氫綅淇敼 | 猸愨瓙猸?/td> | 猸愨瓙猸?/td> |
鏁扮粍鍏嬮殕 | 鍏ㄩ噺鏇存柊 | 猸愨瓙 | 猸?/td> |
瀵硅薄鍏嬮殕 | 瀵硅薄灞炴€ф洿鏂?/td> | 猸愨瓙猸愨瓙 | 猸愨瓙猸?/td> |
ref鏇存柊 | Vue3+澶嶆潅浜や簰 | 猸愨瓙猸愨瓙猸?/td> | 猸愨瓙 |
鍥涖€佺Щ鍔ㄧ涓撳睘閬垮潙鎸囧崡 馃毀
鏈€杩戠粰鏌愮數鍟咥PP鍋氭€ц兘浼樺寲鏃跺彂鐜颁釜鐜拌薄锛氣€?strong>鈥嬪湪iOS涓婃祦鐣呯殑鏁扮粍鎿嶄綔锛屽埌瀹夊崜鍗冨厓鏈轰笂鍙兘鍗℃垚PPT鈥?/strong>鈥嬨€傝繖閲屽垎浜笁涓疄鎴樼粡楠岋細
- 瓒呰繃500鏉℃暟鎹椂锛屾厧鐢ㄥ叏閲忓厠闅?/li>
- 闀垮垪琛ㄤ紭鍏堜娇鐢?code>
- 楂橀鎿嶄綔锛堝瀹炴椂鎼滅储锛夐厤鍚堥槻鎶栦娇鐢?/li>
璇翠釜鍐风煡璇嗭細鍦ㄩ儴鍒嗗崕涓烘満鍨嬩笂锛岃繛缁揩閫熸搷浣滄暟缁勫彲鑳藉鑷碬ebView宕╂簝銆傝В鍐虫柟妗堟槸缁欏叧閿搷浣滃姞200ms闂撮殧锛岃櫧鐒跺奖鍝嶄綋楠岋紝浣嗘€绘瘮闂€€寮恒€?/p>
浜斻€佺嫭瀹舵暟鎹彮绉?馃攳
鍘诲勾鎴戜滑鍥㈤槦鍋氳繃鍘嬪姏娴嬭瘯锛氬湪绾㈢背Note9涓婏紝鐢ㄤ笉鍚屾柟寮忔洿鏂?000鏉℃暟鎹細
- 鐩存帴璧嬪€硷細鍗¢】3.2绉?/li>
- splice鏂规硶锛氬崱椤?.8绉?/li>
- $set鍒嗘壒鏇存柊锛氬崱椤?.9绉?/li>
- ref澧為噺鏇存柊锛氬崱椤?.4绉?/li>
杩欐暟鎹鏄庡暐锛熲€?strong>鈥嬬Щ鍔ㄧ寮€鍙戜笉鑳藉彧鑰冭檻鍔熻兘瀹炵幇锛屽繀椤绘妸鎬ц兘浼樺寲鍒昏繘DNA閲屸€?/strong>鈥嬨€傜壒鍒槸鐜板湪鐢ㄦ埛鎹㈡満鍛ㄦ湡鎷夐暱锛屼腑浣庣鏈哄競鍦哄崰姣旇秴杩?0%锛屽挶浠殑浠g爜寰楃収椤捐繖浜?鑰佺埛鏈?銆?/p>
璇寸偣鎺忓績绐濆瓙鐨勮瘽
骞蹭簡浜斿勾绉诲姩绔紑鍙戯紝鍙戠幇涓湁瓒g幇璞★細寰堝鏂版墜鎬绘兂鎵?涓€鎷涢矞鍚冮亶澶?鐨勮В鍐虫柟妗堛€備絾鐜板疄鏄紝鈥?strong>鈥嬩笉鍚屾満鍨嬨€佷笉鍚屽満鏅€佷笉鍚屾暟鎹噺锛岄渶瑕佺殑澶勭悊鏂瑰紡鍙兘瀹屽叏涓嶅悓鈥?/strong>鈥嬨€傚缓璁ぇ瀹跺湪鎺屾彙鍩虹鏂规硶鍚庯紝澶氱湡鏈鸿皟璇曪紝鐗瑰埆鏄壘鍙颁袱涓夊勾鍓嶇殑鏃ф墜鏈鸿瘯璇曪紝淇濆噯鑳藉彂鐜版柊澶ч檰銆?/p>
鏈€鍚庨€佸ぇ瀹朵釜閿﹀泭锛氫笅娆¢亣鍒版暟缁勪笉鏇存柊锛屽厛鍒€ョ潃鏀逛唬鐮併€傛墦寮€chrome鐨勭Щ鍔ㄧ璋冭瘯妯″紡锛屽嬀閫塁PU鑺傛祦妯℃嫙浣庣鏈猴紝璇翠笉瀹氬氨鑳藉鐜伴棶棰樸€傝浣忥紝绉诲姩绔紑鍙戞渶閲嶈鐨勪笉鏄偒鎶€锛岃€屾槸璁╂渶鐮寸殑鎵嬫満閮借兘璺戦『鐣咃紝杩欐墠鏄湡鏈簨锛?/p>
本文由嘻道妙招独家原创,未经允许,严禁转载