1. 主页 > 好文章

移动端开发:Vue中正确修改数组触发视图回显

鏈夋病鏈夐亣鍒拌繃鍦ㄦ墜鏈轰笂婊戝姩鍒楄〃锛屾暟鎹娲讳笉鏇存柊鐨勬儏鍐碉紵鎵嬫寚澶撮兘蹇妸灞忓箷鎼撳嚭鐏槦瀛愪簡锛岄〉闈㈣繕鏄汗涓濅笉鍔紵浠婂ぉ鍜变滑灏辨潵鎺版壇鎺版壇杩欎釜璁╃Щ鍔ㄧ寮€鍙戝ご绉冪殑缁忓吀闂銆?/p>

涓€銆佺Щ鍔ㄧ涓哄暐鏇村鏄撹俯鍧戯紵馃摫

鍏堣涓湡瀹炴渚嬶細涓婂懆鏈変釜瀛﹀憳鍋歍ODO鍒楄〃搴旂敤锛屽湪鐢佃剳涓婃祴璇曞ソ濂界殑锛岀粨鏋滅敤鎵嬫満鎵撳紑鈥斺€斿畬鎴愪簨椤瑰嬀閫夊悗姝绘椿涓嶅埛鏂帮紒鎬ュ緱浠栧樊鐐规妸鎵嬫満鎵旀按閲屻€備綘鐚滈棶棰樺嚭鍦ㄥ摢锛熲€?strong>鈥嬬Щ鍔ㄧ瑙︽帶浜嬩欢鍜屽搷搴斿紡鏇存柊浜х敓浜嗗濡欏寲瀛﹀弽搴斺€?/strong>鈥嬨€?/p>

杩欓噷瑕佹暡榛戞澘浜嗭細绉诲姩绔紑鍙戞湁涓変釜鐗规畩鐐癸細

  1. 鈥?strong>鈥嬫墜鍔挎搷浣滈绻佲€?/strong>鈥嬶紙婊戝姩/闀挎寜/鎷栨嫿锛?/li>
  2. 鈥?strong>鈥嬫€ц兘瑕佹眰鏇撮珮鈥?/strong>鈥嬶紙鍐呭瓨鍚冪揣锛?/li>
  3. 鈥?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>浣跨敤銆?/p>


鎷涘紡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>鈥嬨€傝繖閲屽垎浜笁涓疄鎴樼粡楠岋細

  1. 瓒呰繃500鏉℃暟鎹椂锛屾厧鐢ㄥ叏閲忓厠闅?/li>
  2. 闀垮垪琛ㄤ紭鍏堜娇鐢?code>
  3. 楂橀鎿嶄綔锛堝瀹炴椂鎼滅储锛夐厤鍚堥槻鎶栦娇鐢?/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>

本文由嘻道妙招独家原创,未经允许,严禁转载