欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳細(xì)聊聊vue中組件的props屬性

 更新時(shí)間:2021年11月02日 12:01:06   作者:suoh''''''''''''''''s Blog  
父子組件之間的通信就是props down,events up,父組件通過屬性props向下傳遞數(shù)據(jù)給子組件,子組件通過事件events 給父組件發(fā)送消息,這篇文章主要給大家介紹了關(guān)于vue中組件的props屬性的相關(guān)資料,需要的朋友可以參考下

今天這篇文章,讓你徹底學(xué)會(huì)props屬性……

props主要用于組件的傳值,他的工作就是為了接收外面?zhèn)鬟^來的數(shù)據(jù),與data、el、ref是一個(gè)級(jí)別的配置項(xiàng)。

問題一:那props具體是怎么使用呢?原理又是什么呢?往下看

1、【定義被調(diào)用組件】首先,我們先定義一個(gè)person組件,用于顯示個(gè)人信息的組件,我們放了一個(gè)人的姓名,性別,以及年齡,定義好這個(gè)組件之后,就可以等待其他組件進(jìn)行調(diào)用。那么既然別的組件可以調(diào)用,我們就需要再定義一個(gè)props屬性,用于接收別的組件傳進(jìn)來的值。

 注意:組件中name、sex、age都是一個(gè)prop,將三個(gè)屬性放到一起,就是props,這就是props的由來,是prop的復(fù)數(shù)形式,代表多個(gè)prop屬性的集合。

 2、【調(diào)用組件】此時(shí)我們?cè)俣x一個(gè)info組件,用于展示這個(gè)人的基本信息,進(jìn)行對(duì)person組價(jià)的調(diào)用實(shí)現(xiàn)信息的展示,分為下圖四個(gè)步驟進(jìn)行調(diào)用。并傳入?yún)?shù)

 3、【看效果】傳入成功。

問題二:那如果我們想給年齡加1歲,怎么實(shí)現(xiàn)?

我們可能會(huì)直接這樣加1

看效果是否能實(shí)現(xiàn),變成19,看下圖顯然是不正確的。因?yàn)槟銈魅氲哪挲g是個(gè)字符串18,所以加1只會(huì)在18后面進(jìn)行拼接。

然后有的人說,那傳數(shù)字,怎么傳數(shù)字呢?很簡(jiǎn)單,一個(gè)符號(hào)搞定。

我們只需要在age前面加上冒號(hào) :他就會(huì)只識(shí)別雙引號(hào)里面的東西18 ,否則識(shí)別的是雙引號(hào)18

看下效果,此時(shí)就成功了。

問題三:對(duì)于年齡這一類型,我們最希望拿到的是什么數(shù)據(jù)類型?

肯定是數(shù)字類型,但是有人非要傳字符串類型,就會(huì)影響我們對(duì)年齡的計(jì)算,比如上面的加1……那么我們?nèi)绾蜗拗祁愋湍兀?/strong>

這時(shí)候props不能再用[]去定義,需要用{},因?yàn)橄拗祁愋蜁r(shí),props就是作為一個(gè)對(duì)象去使用;

下面就是我們將三個(gè)屬性分別做了限制。

我們把年齡做了number類型限制后,再傳入字符串18,看有什么變化?

此時(shí)發(fā)現(xiàn)控制臺(tái),會(huì)報(bào)錯(cuò),顯示age的數(shù)據(jù)類型不匹配。

雖然不影響展示,但是會(huì)報(bào)錯(cuò)。這可以給我們提供一個(gè)明確的提示。方便我們規(guī)范的傳入數(shù)據(jù)。

 

問題四:可以限制類型,那是不是也可以限制是否必傳呢?

答:當(dāng)然可以。

假設(shè)姓名必傳,其他非必傳。

類型屬性:type:xx

必傳屬性:required:true

默認(rèn)屬性:default:xx

name必傳,那么我們不傳試試,年齡不傳默認(rèn)18

結(jié)果,控制臺(tái)同樣報(bào)錯(cuò),提示,name是必傳屬性。年齡我們沒傳,也成功展示的是默認(rèn)值,19是因?yàn)橐婚_始對(duì)年齡進(jìn)行了加1操作,這樣我們就成功對(duì)屬性進(jìn)行了限制。

 

對(duì)以上總結(jié):

props在接收數(shù)據(jù)的同時(shí),對(duì)數(shù)據(jù)進(jìn)行了類型限制+默認(rèn)值的指定+必要性的限制

問題五:props接收的屬性值可以修改嗎?

答:不可以

我們添加一個(gè)button,以及點(diǎn)擊事件

 注意:我們要訪問props里面的屬性值,通過this.即可找到

 

 查看結(jié)果,發(fā)現(xiàn)頁面可以顯示,但是控制臺(tái)報(bào)錯(cuò),因此它是不可修改的

問題六:必須要修改props屬性值,怎么辦?

答:通過data去間接修改

我們?cè)赿ata里面重新定義一個(gè)變量去接收props屬性。這個(gè)變量最好不要重名,重名的話,優(yōu)先獲取props屬性值,優(yōu)先級(jí)props>data。然后我們?cè)诓僮骰蛘遠(yuǎn)tml綁定值的時(shí)候,都去操作data里面新定義的變量

此時(shí)可以看到,修改成功,也沒有報(bào)錯(cuò):

總結(jié):配置項(xiàng)props

-------讓組件接收外部傳來的數(shù)據(jù)

 接收數(shù)據(jù)三種方式:

(1)只接收:props: ['name','age','sex']

(2)接收并限制類型:props: { "name":Number }

(3)限制類型、限制必要性指定默認(rèn)值:

    props:{
        "name":{
            type:String,
            required:true
        },
        "age":{
            type:Number,
            default:18
        },
        "sex":{
            type:String,
            default:'男'
        },
    },

注意:props是只讀的,vue底層會(huì)檢測(cè)你對(duì)props的修改,如果進(jìn)行了修改,控制臺(tái)會(huì)報(bào)錯(cuò),必須修改,就復(fù)制一份到data中,通過data去修改數(shù)據(jù)。

到此這篇關(guān)于vue中組件的props屬性的文章就介紹到這了,更多相關(guān)vue組件的props屬性內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue基礎(chǔ)之MVVM,模板語法和數(shù)據(jù)綁定

    Vue基礎(chǔ)之MVVM,模板語法和數(shù)據(jù)綁定

    這篇文章主要為大家介紹了Vue之MVVM,模板語法和數(shù)據(jù)綁定,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • vue+elementUI動(dòng)態(tài)增加表單項(xiàng)并添加驗(yàn)證的代碼詳解

    vue+elementUI動(dòng)態(tài)增加表單項(xiàng)并添加驗(yàn)證的代碼詳解

    這篇文章主要介紹了vue+elementUI動(dòng)態(tài)增加表單項(xiàng)并添加驗(yàn)證的代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • vue?css?相對(duì)路徑導(dǎo)入問題級(jí)踩坑記錄

    vue?css?相對(duì)路徑導(dǎo)入問題級(jí)踩坑記錄

    這篇文章主要介紹了vue?css?相對(duì)路徑導(dǎo)入問題級(jí)踩坑記錄,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • element-ui select多選綁定回顯值問題

    element-ui select多選綁定回顯值問題

    這篇文章主要介紹了element-ui select多選綁定回顯值問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Vue 動(dòng)態(tài)添加路由及生成菜單的方法示例

    Vue 動(dòng)態(tài)添加路由及生成菜單的方法示例

    這篇文章主要介紹了Vue 動(dòng)態(tài)添加路由及生成菜單的方法示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • Vue3 響應(yīng)式偵聽與計(jì)算的實(shí)現(xiàn)

    Vue3 響應(yīng)式偵聽與計(jì)算的實(shí)現(xiàn)

    這篇文章主要介紹了Vue3 響應(yīng)式偵聽與計(jì)算的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • 淺談Vue Element中Select下拉框選取值的問題

    淺談Vue Element中Select下拉框選取值的問題

    下面小編就為大家分享一篇淺談Vue Element中Select下拉框選取值的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • vue頂部菜單欄實(shí)現(xiàn)小結(jié)

    vue頂部菜單欄實(shí)現(xiàn)小結(jié)

    這篇文章主要介紹了vue頂部菜單欄實(shí)現(xiàn)小結(jié),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • vue?cli+axios踩坑記錄+攔截器使用方式,代理跨域proxy

    vue?cli+axios踩坑記錄+攔截器使用方式,代理跨域proxy

    這篇文章主要介紹了vue?cli+axios踩坑記錄+攔截器使用方式,代理跨域proxy,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue+ts大文件切片上傳的實(shí)現(xiàn)示例

    vue+ts大文件切片上傳的實(shí)現(xiàn)示例

    在Vue項(xiàng)目中,大圖片和多數(shù)據(jù)Excel等大文件的上傳是一個(gè)非常常見的需求,本文主要介紹了vue+ts大文件切片上傳,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-01-01

最新評(píng)論