怎么利用Vuev-model實現一個自定義的表單組件

這篇文章主要介紹怎么利用Vue v-model實現一個自定義的表單組件,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

主要從事網頁設計、PC網站建設(電腦版網站建設)、wap網站建設(手機版網站建設)、響應式網站、程序開發、微網站、微信小程序等,憑借多年來在互聯網的打拼,我們在互聯網網站建設行業積累了豐富的成都網站設計、網站制作、網絡營銷經驗,集策劃、開發、設計、營銷、管理等多方位專業化運作于一體,具備承接不同規模與類型的建設項目的能力。

為什么要使用Vue

Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以創建可維護性和可測試性更強的代碼庫,Vue允許可以將一個網頁分割成可復用的組件,每個組件都包含屬于自己的HTML、CSS、JavaScript,以用來渲染網頁中相應的地方,所以越來越多的前端開發者使用vue。

功能描述:

通過點擊按鈕,可以增減購物數量

組件名稱是 CouterBtn

最終效果如下

怎么利用Vue v-model實現一個自定義的表單組件

我們使用 vue-cli搭建基本的開發環境,這也是最快的進行 .vue組件開發的方式

對于入口組件  App.vue (可以暫時忽略其他細節,我們的重點是如何寫組件)

App.vue

 <template>
 <div id="app">
 <h5>這是一個利用 v-model實現的自定義的表單組件</h5>
 <h7>CouterBtn組件的值 <i> {{ btnValue }} </i></h7>
 5. <counter-btn v-model="btnValue"></counter-btn>
 <form class="" action="/add" method="post">
  <!-- 真實情況請將 type改為hidden -->
  <label for="count">值綁定到 input 隱藏域里</label>
  <input type="text" name="count" :value="btnValue.res" id="count">
10. </form>
 </div>
 </template>
 <script>
 import CounterBtn from './components/CouterBtn.vue'
15. export default {
 data() {
  return {
  btnValue: {}
  }
20. },
 components: {
  CounterBtn
 }
 }
25. </script>
 <style lang="stylus">
 h7 i
 border 1px dotted
 form
30. margin-top 20px
 padding 20px
 border 1px dotted #ccc
 label
  vertical-align: middle
35. </style>

下面我來對 App.vue中的一些代碼進行一些說明,根據代碼行數來說明

4 : 我們使用 {{ btnValue }}來獲取自定義組件 counter-btn的值, 這里僅僅是展示效果用 

5: 我們使用了counter-btn ,自定義的組件 

9: 我們將自定義組件的值,綁定到我們的表單組件 input中去, 在真實的情況下, 此 input的類型可能為 hidden類型 

21: 由于我們需要在App.vue組件中使用我們自定義的組件 counter-btn,所以需要使用 components注冊組件, 這里還使用了 ES6的對象解構 

26: 我們使用CSS預處理器為stylus, 前提是你的 node_modules中要安裝此npm包和loader,vue-cli已經幫我們處理好了stylus的編譯; 根據個人情況選擇 

我們自己設計的組件通過 v-model,把組件內部的值傳給了它所綁定的值

下面我們來看看我們的組件的實現

CounterBtn.vue

 <template>
 <div class="coutter-wrapper">
 <button type="button" @click="plus">+</button>
 <button type="button">{{ result }}</button>
5. <button type="button" @click="minus">-</button>
 </div>
 </template>
 <script>
 export default {
10. methods: {
 minus() {
 this.result--;
 this.$emit('input', {res: this.result, other: '--'})
 },
15. plus() {
 this.result++;
 this.$emit('input', {res: this.result, other: '++'})
 }
 },
20. data() {
 return {
 result: 0,
 }
 }
25. }
 </script>
 <style lang="stylus" scoped>
 button
 border 0
30. outline 0
 border-radius 3px
 button:nth-child(2)
 width 200px 
 </style>

我們可以看到組件的實現非常簡單, 3個button搞定; 這里最關鍵的代碼是

this.$emit('input', {res: this.result, other: '++'})

通過 觸發 input事件和自定的數據來實現把數據暴露給 v-model綁定的屬性值

以上是“怎么利用Vue v-model實現一個自定義的表單組件”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創新互聯行業資訊頻道!

名稱欄目:怎么利用Vuev-model實現一個自定義的表單組件
網站路徑:http://m.kartarina.com/article40/pphiho.html

成都網站建設公司_創新互聯,為您提供企業網站制作Google、靜態網站、品牌網站設計、自適應網站、外貿建站

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都網頁設計公司
主站蜘蛛池模板: 亚洲av午夜精品无码专区| 色综合久久中文字幕无码| 精品久久久久久无码中文野结衣| 久久无码av亚洲精品色午夜| 亚洲人成无码网WWW| 无码人妻精品一区二区三区99仓本 | 国产日韩AV免费无码一区二区| 国产亚洲AV无码AV男人的天堂| 久久av无码专区亚洲av桃花岛| 性色AV无码中文AV有码VR| 日韩精品无码一区二区三区| 亚洲AV无码男人的天堂| 亚洲av中文无码乱人伦在线咪咕| 亚洲AV无码一区二区一二区| 国产成A人亚洲精V品无码| 无翼乌工口肉肉无遮挡无码18| 久久久久亚洲Av无码专| 无码人妻精品一区二区三区久久| 国产成人无码专区| 加勒比无码一区二区三区| 日韩精品无码一本二本三本 | 国产精品无码一区二区三级| 国产成年无码v片在线| 蜜桃臀无码内射一区二区三区| 中文有无人妻vs无码人妻激烈| 无码AV动漫精品一区二区免费 | 无码精品前田一区二区| 亚洲国产精品无码久久久秋霞1 | 欧洲精品久久久av无码电影 | 麻豆精品无码国产在线果冻| 麻豆国产精品无码视频| 久久久久亚洲av无码专区蜜芽| 中文字幕丰满乱子无码视频| 国产亚洲情侣一区二区无码AV | 国产精品亚韩精品无码a在线| 免费看成人AA片无码视频吃奶| 国产嫖妓一区二区三区无码| 精品久久久久久无码中文字幕一区| 亚洲AV无码资源在线观看| 精品人妻无码一区二区色欲产成人 | 人妻无码久久中文字幕专区|