91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

VUE中data配置的作用是什么

發布時間:2023-02-27 14:06:06 來源:億速云 閱讀:141 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“VUE中data配置的作用是什么”,內容詳細,步驟清晰,細節處理妥當,希望這篇“VUE中data配置的作用是什么”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

1.data是什么?有什么作用?

data是Vue實例中一個配置項。用來存儲vue實例或者組件里面的數值。

2.data的存在位置差異(data配置項存在于兩種位置)

2.1.當data存在于Vue實例中時,它既可以是以一個對象的形式(鍵值對)。

在Vue的data屬性定義以下數據類型:

1、字符串

2、整數

3、數組

4、對象

5、對象數組

data: {
                    // 定義字符串
                    name: "谷哥的小弟",
                    // 定義整數
                    number:9527,
                    // 定義數組
                    hobby:["籃球","足球","擊劍"],
                    // 定義對象
                    user:{id: 21, name: "zxx", age: 50},
                    // 定義對象數組
                    users:[
                        {id: 21, name: "zxx", age: 50},
                        {id: 22, name: "zxc", age: 51},
                        {id: 23, name: "zcc", age: 52},
                    ]
                }

2.1也可以是一個函數的形式。

const app = new Vue({
    el:"#app",
    // 對象格式
    data:{
        foo:"foo"
    },
    // 函數格式
    data(){
        return {
             foo:"foo"
        }
    }

2.2當data存在于組件中時,它只能是一個函數

Vue.component('component1',{
    template:`<div>組件</div>`,
     data(){
        return {
             foo:"foo"
        }
    }
})

3.為什么在組件中data只能是一個函數呢?

Vue的官方文檔中也有說組件中的data必須使用函數否則會報錯,這是為什么呢?

這就要追溯到我們的Jvascript的對象了,眾所周知Javascript的對象屬于引用數據類型,如果將一個對象賦值給另一個對象他并不是將該對象的值賦給新變量,而是在內存中將起初申明的對象去指向這個新對象。

let obj = {
    name: "小明",
    age:19
}
let obj1 = obj 
obj.name = "小紅"
// 此時   obj1.name == "小紅"
// 并且   obj.name == "小紅"

這種情況下如果修改obj1中的屬性,obj的數據也會發生變化

為什么要提到這個呢 我們就要理解一下組件 其實就類似原生js的一個構造函數

我們去調用的組件就是相當于原生js我們去實例化的對象加入我們申明一個構造函數 person并改變其中的值

    function Person(name,age){
        this.name = nmae;
        this.age = age ;
        this.race = "漢族"
    }
    let ming = new Person("xiaoming",19)
    let hong = new Person("xiaohong",20)
    console.log(ming)
    console.log(hong)
    // 此時如果我們把小明的名族改了
    ming.race="維吾爾族"
    console.log(ming)
    console.log(hong)
    // 我們再去查看一下會發現,小明小紅都變成了維吾爾族

所以,為了防止對象的變量修改,在組件的data必須要用函數的形式存在,因為只有函數有函數的封閉作用域,這也就是為什么Vue的設計者為什么在組件中使用了一個data卻再次return了一個對象。

讀到這里,這篇“VUE中data配置的作用是什么”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

游戏| 包头市| 曲阳县| 雷州市| 鹤山市| 卢氏县| 定远县| 尼勒克县| 呼图壁县| 东兴市| 屯留县| 汉川市| 张家港市| 伊通| 北安市| 阳新县| 鄂温| 黑龙江省| 鲁甸县| 苗栗县| 金平| 玉屏| 新竹市| 根河市| 南宫市| 监利县| 临澧县| 漯河市| 天镇县| 乌拉特后旗| 株洲市| 浙江省| 襄汾县| 中卫市| 呈贡县| 宜春市| 肥东县| 秦皇岛市| 专栏| 嘉鱼县| 道真|