久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

vue 避免變量賦值后雙向綁定的操作

瀏覽:103日期:2022-11-05 08:20:39

如: this.list = this.list2, 結果在list改變后 list2也改變,這不是我們想要的效果

第一種:

利用 JSON.parse 和 JSON.stringify

this.list= JSON.parse( JSON.stringify(this.list2) )

第二種:

ES6 的解析語法

this.list= { ...this.list2}

this.arr= [...this.arr2]

補充知識:解決vue中v-model綁定的變量賦值給了另一個變量后,兩個變量同時改變

先來看一下問題背景

我們要做一個 搜索+分頁 的功能,使用vue

我們將分頁控件綁定了點擊事件,點擊后提交v-model綁定的formData表單,但是我們忽略了一個問題,就是當輸入的信息改變的情況下,不點擊搜索,直接點擊分頁控件,提交的將會是新現在搜索框中的搜索條件。這樣就不和邏輯了。

于是我們在data中新加了一個表單的對象 submitForm,只有在點擊 查詢 的時候,v-model綁定的 formData 表單才會賦值給這個對象,而翻頁的時候提交的是 submitForm 。這樣就解決了這個問題。

data() { return { formData: { timeStart: ’’, timeEnd: ’’, // 分頁數據 pageNo: 1, pageSize: 10 }, submitForm: { timeStart: ’’, timeEnd: ’’, // 分頁數據 pageNo: 1, pageSize: 10 }, }this.submitForm = this.formData// 用 new也是一樣達不到效果this.submitForm = new Object(this.formData)

但是!!!

submitForm 竟然跟著變了

這是因為在Object賦值的時候,傳遞的不是值,而是引用,他們指向了同一個空間!

解決

第一種:利用 JSON.parse 和 JSON.stringify

this.submitForm = JSON.parse( JSON.stringify(this.formData) )

第二種:ES6 的解析語法

this.submitForm = { ...this.formData }

以上這篇vue 避免變量賦值后雙向綁定的操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 洛川县| 集安市| 湖南省| 乌鲁木齐县| 东平县| 阜南县| 武冈市| 正安县| 喀什市| 前郭尔| 当雄县| 纳雍县| 济源市| 图木舒克市| 尚志市| 南和县| 黄浦区| 水城县| 阜新市| 大竹县| 商都县| 青海省| 阿尔山市| 长武县| 紫云| 普陀区| 海宁市| 弥渡县| 西吉县| 苏尼特左旗| 乡城县| 杭锦后旗| 涡阳县| 衡阳县| 云霄县| 通山县| 高邮市| 务川| 天门市| 南和县| 高州市|