宅男在线永久免费观看网直播,亚洲欧洲日产国码无码久久99,野花社区在线观看视频,亚洲人交乣女bbw,一本一本久久a久久精品综合不卡

全部
常見問題
產品動態(tài)
精選推薦

vue中$set用法詳細講解

管理 管理 編輯 刪除

1、為什么要用set?

在vue中,并不是任何時候數據都是雙向綁定的。
在官方文檔中,有這樣一段話,如下:

352ed202303201120576174.png

從文檔得知,當數據沒有被雙向綁定的時候,我們就需要使用set了

2、set用法

解決數據沒有被雙向綁定我們可以使用 vm.$set 實例方法,該方法是全局方法 Vue.set 的一個別名。

 - this.$set(原數組, 索引值, 需要賦的值)

length的問題還需要用splice方法。

 - vm.items.splice(newLength)

3、什么時候使用set?

set為解決雙向綁定失效而生,我們只需要關注什么時候雙向綁定失效就可以了。

筆者看完了官方文檔以后,總結了一下,只要值的地址沒有改變,vue是檢測不到數據變化的。

共有下面三種情況:

1.當你利用索引直接設置一個數組項時,例如:vm.items[indexOfItem] = newValue

2.當你修改數組的長度時,例如:vm.items.length = newLength

3.由于 JavaScript 的限制,Vue不能檢測對象屬性的添加或刪除

此處針對第三點做一些說明:

var vm = new Vue({
  data: {
    a: 1
  }
})
// `vm.a` 現在是響應式的

vm.b = 2
// `vm.b` 不是響應式的

從上面的代碼我們可以知道vm.b不是響應式的,簡單的來說,如果對象中原來沒有這個key,新增的key是無法雙向綁定的。

當然這里我們同樣可以用set去解決這個問題:

vm.$set(vm.userProfile, 'age', 27)

如果我們添加的屬性很多條,可能就需要寫一個循環(huán)來多次set。當然你也可能使用Object.assign,這里有一些需要注意的地方。

如果你想添加新的響應式屬性,下面這樣寫是不行的。

Object.assign(vm.userProfile, {
  age: 27,
  favoriteColor: 'Vue Green'
})

下面這樣才是正確的。

vm.userProfile = Object.assign({}, vm.userProfile, {
  age: 27,
  favoriteColor: 'Vue Green'
})

4、文檔地址

https://cn.vuejs.org/v2/guide/list.html#logo

請登錄后查看

CRMEB-慕白寒窗雪 最后編輯于2023-03-20 11:23:38

快捷回復
回復
回復
回復({{post_count}}) {{!is_user ? '我的回復' :'全部回復'}}
排序 默認正序 回復倒序 點贊倒序

{{item.user_info.nickname ? item.user_info.nickname : item.user_name}} LV.{{ item.user_info.bbs_level || item.bbs_level }}

作者 管理員 企業(yè)

{{item.floor}}# 同步到gitee 已同步到gitee {{item.is_suggest == 1? '取消推薦': '推薦'}}
{{item.is_suggest == 1? '取消推薦': '推薦'}}
沙發(fā) 板凳 地板 {{item.floor}}#
{{item.user_info.title || '暫無簡介'}}
附件

{{itemf.name}}

{{item.created_at}}  {{item.ip_address}}
打賞
已打賞¥{{item.reward_price}}
{{item.like_count}}
{{item.showReply ? '取消回復' : '回復'}}
刪除
回復
回復

{{itemc.user_info.nickname}}

{{itemc.user_name}}

回復 {{itemc.comment_user_info.nickname}}

附件

{{itemf.name}}

{{itemc.created_at}}
打賞
已打賞¥{{itemc.reward_price}}
{{itemc.like_count}}
{{itemc.showReply ? '取消回復' : '回復'}}
刪除
回復
回復
查看更多
打賞
已打賞¥{{reward_price}}
1259
{{like_count}}
{{collect_count}}
添加回復 ({{post_count}})

相關推薦

快速安全登錄

使用微信掃碼登錄
{{item.label}} 加精
{{item.label}} {{item.label}} 板塊推薦 常見問題 產品動態(tài) 精選推薦 首頁頭條 首頁動態(tài) 首頁推薦
取 消 確 定
回復
回復
問題:
問題自動獲取的帖子內容,不準確時需要手動修改. [獲取答案]
答案:
提交
bug 需求 取 消 確 定
打賞金額
當前余額:¥{{rewardUserInfo.reward_price}}
{{item.price}}元
請輸入 0.1-{{reward_max_price}} 范圍內的數值
打賞成功
¥{{price}}
完成 確認打賞

微信登錄/注冊

切換手機號登錄

{{ bind_phone ? '綁定手機' : '手機登錄'}}

{{codeText}}
切換微信登錄/注冊
暫不綁定
CRMEB客服

CRMEB咨詢熱線 咨詢熱線

400-8888-794

微信掃碼咨詢

CRMEB開源商城下載 源碼下載 CRMEB幫助文檔 幫助文檔
返回頂部 返回頂部
CRMEB客服