1. <ul id="0c1fb"></ul>

      <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
      <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区

      RELATEED CONSULTING
      相關咨詢
      選擇下列產品馬上在線溝通
      服務時間:8:30-17:00
      你可能遇到了下面的問題
      關閉右側工具欄

      新聞中心

      這里有您想知道的互聯網營銷解決方案
      怎么在Vue中使用props方法-創(chuàng)新互聯

      本篇文章為大家展示了怎么在Vue中使用props方法,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

      讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:主機域名虛擬主機、營銷軟件、網站建設、白水網站維護、網站推廣。

      Vue props用法詳解

      組件接受的選項之一 props 是 Vue 中非常重要的一個選項。父子組件的關系可以總結為:

      props down, events up

      父組件通過 props 向下傳遞數據給子組件;子組件通過 events 給父組件發(fā)送消息。

      父子級組件

      比如我們需要創(chuàng)建兩個組件 parent 和 child。需要保證每個組件可以在相對隔離的環(huán)境中書寫,這樣也能提高組件的可維護性。

      這里我們先定義父子兩個組件和一個 Vue 對象:

      var childNode = {
       template: `
        
      childNode
        ` }; var parentNode = {  template: `   
                
        `,  components: {  child: childNode  } }; new Vue({  el: "#example",  components: {  parent: parentNode  } });
      
       
      

      這里的 childNode 定義的 template 是一個 div,并且內容是"childNode"字符串。

      而在 parentNode 的 template 中定義了 div 的 class 名叫 parent 并且包含了兩個 child 組件。

      如果大家想對VUE.JS有更加深入系統的學習,可以參閱 Vue.js實戰(zhàn) PDF高質量掃描版 這本經典讀物

      靜態(tài) props

      組件實例的作用域是孤立的。這意味著不能(也不應該)在子組件的模板中直接飲用父組件的數據。要讓子組件使用父組件的數據,需要通過子組件的 props 選項。

      父組件向子組件傳遞數據分為兩種方式:動態(tài)和靜態(tài),這里先介紹靜態(tài)方式。

      子組件要顯示的用 props 聲明它期望獲得的數據

      修改上例中的代碼,給 childNode 添加一個 props 選項和需要的forChildMsg數據;

      然后在父組件中的占位符添加特性的方式來傳遞數據。

      var childNode = {
       template: `
        
         {{forChildMsg}}   
        `,  props: ["for-child-msg"] }; var parentNode = {  template: `   
         

      parentNode

                
        `,  components: {  child: childNode  } };

      命名規(guī)范

      對于 props 聲明的屬性,在父組件的 template 模板中,屬性名需要使用中劃線寫法;

      子組件 props 屬性聲明時,使用小駝峰或者中劃線寫法都可以;而子組件的模板使用從父組件傳來的變量時,需要使用對應的小駝峰寫法。別擔心,Vue 能夠正確識別出小駝峰和下劃線命名法混用的變量,如這里的forChildMsgfor-child-msg是同一值。

      動態(tài) props

      在模板中,要動態(tài)地綁定父組件的數據到子組件模板的 props,和綁定 Html 標簽特性一樣,使用v-bind綁定;

      基于上述靜態(tài) props 的代碼,這次只需要改動父組件:

      var parentNode = {
       template: `
        
         

      parentNode

                
        `,  components: {  child: childNode  },  data: function() {  return {   childMsg1: "Dynamic props msg for child-1",   childMsg2: "Dynamic props msg for child-2"  };  } };

      在父組件的 data 的 return 數據中的 childMsg1 和 childMsg2 會被傳入子組件中,

      props 驗證

      驗證傳入的 props 參數的數據規(guī)格,如果不符合數據規(guī)格,Vue 會發(fā)出警告。

      能判斷的所有種類(也就是 type 值)有:String, Number, Boolean, Function, Object, Array, Symbol

      Vue.component("example", {
       props: {
       // 基礎類型檢測, null意味著任何類型都行
       propA: Number,
       // 多種類型
       propB: [String, Number],
       // 必傳且是String
       propC: {
        type: String,
        required: true
       },
       // 數字有默認值
       propD: {
        type: Number,
        default: 101
       },
       // 數組、默認值是一個工廠函數返回對象
       propE: {
        type: Object,
        default: function() {
        console.log("propE default invoked.");
        return { message: "I am from propE." };
        }
       },
       // 自定義驗證函數
       propF: {
        isValid: function(value) {
        return value > 100;
        }
       }
       }
      });
      let childNode = {
       template: "
      {{forChildMsg}}
      ",  props: {  "for-child-msg": Number  } }; let parentNode = {  template: `            
        `,  components: {  child: childNode  },  data() {  return {   // 當這里是字符串 "123456"時會報錯   msg: 123456  };  } };

      還可以在 props 定義的數據中加入自定義驗證函數,當函數返回 false 時,輸出警告。

      比如我們把上述例子中的 childNode 的for-child-msg修改成一個對象,并包含一個名叫validator的函數,該命名是規(guī)定叫validator的,自定義函數名不會生效。

      let childNode = {
       template: "
      {{forChildMsg}}
      ",  props: {  "for-child-msg": {   validator: function(value) {   return value > 100;   }  }  } };

      在這里我們給for-child-msg變量設置了validator函數,并且要求傳入的值必須大于 100,否則報出警告。

      單向數據流

      props 是單向綁定的:當父組件的屬性變化時,將傳導給子組件,但是不會反過來。這是為了防止子組件五一修改父組件的狀態(tài)。

      所以不應該在子組件中修改 props 中的值,Vue 會報出警告。

      let childNode = {
       template: `
         
         
          子組件數據         
         

      {{forChildMsg}}

         
      `,  props: {  "for-child-msg": String  } }; let parentNode = {  template: `        
          父組件數據         
         

      {{msg}}

             
        `,  components: {  child: childNode  },  data() {  return {   msg: "default string."  };  } };

      這里我們給父組件和子組件都有一個輸入框,并且顯示出父組件數據和子組件的數據。當我們在父組件的輸入框輸入新數據時,同步的子組件數據也被修改了;這就是 props 的向子組件傳遞數據。而當我們修改子組件的輸入框時,瀏覽器的控制臺則報出錯誤警告

      [Vue warn]: Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-renders. Instead, use a data or computed property based on the prop's value. Prop being mutated: "forChildMsg"

      修改 props 數據

      通常有兩種原因:

      1. prop 作為初始值傳入后,子組件想把它當做局部數據來用

      2. prop 作為初始值傳入后,由子組件處理成其他數據輸出

      應對辦法是

      定義一個局部變量,并用 prop 的值初始化它

      但是由于定義的 ownChildMsg 只能接受 forChildMsg 的初始值,當父組件要傳遞的值變化發(fā)生時,ownChildMsg 無法收到更新。

      let childNode = {
       template: `
         
         
          子組件數據         
         

      {{forChildMsg}}

         

      ownChildMsg : {{ownChildMsg}}

         
      `,  props: {  "for-child-msg": String  },  data() {  return { ownChildMsg: this.forChildMsg };  } };

      這里我們加了一個

      用于查看 ownChildMsg 數據是否變化,結果發(fā)現只有默認值傳遞給了 ownChildMsg,父組件改變只會變化到 forChildMsg,不會修改 ownChildMsg。

      定義一個計算屬性,處理 prop 的值并返回

      由于是計算屬性,所以只能顯示值,不能設置值。我們這里設置的是一旦從父組件修改了 forChildMsg 數據,我們就把 forChildMsg 加上一個字符串"---ownChildMsg",然后顯示在屏幕上。這時是可以每當父組件修改了新數據,都會更新 ownChildMsg 數據的。

      let childNode = {
       template: `
         
         
          子組件數據         
         

      {{forChildMsg}}

         

      ownChildMsg : {{ownChildMsg}}

         
      `,  props: {  "for-child-msg": String  },  computed: {  ownChildMsg() {   return this.forChildMsg + "---ownChildMsg";  }  } };

      更加妥帖的方式是使用變量存儲 prop 的初始值,并用 watch 來觀察 prop 值得變化。發(fā)生變化時,更新變量的值。

      let childNode = {
       template: `
         
         
          子組件數據         
         

      {{forChildMsg}}

         

      ownChildMsg : {{ownChildMsg}}

         
      `,  props: {  "for-child-msg": String  },  data() {  return {   ownChildMsg: this.forChildMsg  };  },  watch: {  forChildMsg() {   this.ownChildMsg = this.forChildMsg;  }  } };

      上述內容就是怎么在Vue中使用props方法,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注創(chuàng)新互聯成都網站設計公司行業(yè)資訊頻道。

      另外有需要云服務器可以了解下創(chuàng)新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。


      文章名稱:怎么在Vue中使用props方法-創(chuàng)新互聯
      URL地址:http://www.ef60e0e.cn/article/ddeocg.html
      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区
      1. <ul id="0c1fb"></ul>

        <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
        <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

        大余县| 胶州市| 滦南县| 绥棱县| 宜兰县| 彰武县| 醴陵市| 怀宁县| 榆林市| 吉木乃县| 济源市| 商丘市| 嘉兴市| 会昌县| 舒兰市| 红河县| 阿克苏市| 眉山市| 新宁县| 和田市| 梅州市| 陵水| 波密县| 台东县| 永善县| 苍梧县| 从化市| 久治县| 新沂市| 布尔津县| 班戈县| 磐石市| 东辽县| 肇源县| 宁陕县| 元氏县| 张家口市| 桑日县| 南昌县| 和政县| 乌苏市|