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

利用Vue v-model實(shí)現(xiàn)一個自定義的表單組件

 更新時間:2017年04月27日 08:38:11   作者:苦練內(nèi)功  
本篇文章主要介紹了利用Vue v-model實(shí)現(xiàn)一個自定義的表單組件的相關(guān)知識。具有很好的參考價值。下面跟著小編一起來看下吧

功能描述:

通過點(diǎn)擊按鈕,可以增減購物數(shù)量

組件名稱是 CouterBtn

最終效果如下

我們使用 vue-cli搭建基本的開發(fā)環(huán)境,這也是最快的進(jìn)行 .vue組件開發(fā)的方式

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

App.vue

 <template>
 <div id="app">
 <h4>這是一個利用 v-model實(shí)現(xiàn)的自定義的表單組件</h4>
 <h6>CouterBtn組件的值 <i> {{ btnValue }} </i></h6>
 5. <counter-btn v-model="btnValue"></counter-btn>
 <form class="" action="/add" method="post">
  <!-- 真實(shí)情況請將 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">
 h6 i
 border 1px dotted
 form
30. margin-top 20px
 padding 20px
 border 1px dotted #ccc
 label
  vertical-align: middle
35. </style>

下面我來對 App.vue中的一些代碼進(jìn)行一些說明,根據(jù)代碼行數(shù)來說明

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

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

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

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

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

我們自己設(shè)計(jì)的組件通過 v-model,把組件內(nèi)部的值傳給了它所綁定的值

下面我們來看看我們的組件的實(shí)現(xiàn)

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>

我們可以看到組件的實(shí)現(xiàn)非常簡單, 3個button搞定; 這里最關(guān)鍵的代碼是

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

通過 觸發(fā) input事件和自定的數(shù)據(jù)來實(shí)現(xiàn)把數(shù)據(jù)暴露給 v-model綁定的屬性值

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家

相關(guān)文章

  • vite+vue3+ts項(xiàng)目新建以及解決遇到的問題

    vite+vue3+ts項(xiàng)目新建以及解決遇到的問題

    vite是一個基于Vue3單文件組件的非打包開發(fā)服務(wù)器,它具有快速的冷啟動,不需要等待打包操作,下面這篇文章主要給大家介紹了關(guān)于vite+vue3+ts項(xiàng)目新建以及解決遇到的問題的相關(guān)資料,需要的朋友可以參考下
    2023-06-06
  • 詳解Vue SPA項(xiàng)目優(yōu)化小記

    詳解Vue SPA項(xiàng)目優(yōu)化小記

    這篇文章主要介紹了詳解Vue SPA項(xiàng)目優(yōu)化小記,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07
  • 如何讓vue長列表快速加載

    如何讓vue長列表快速加載

    這篇文章主要介紹了如何讓vue長列表快速加載,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下
    2021-03-03
  • vue中transition動畫使用(移動端頁面切換左右滑動效果)

    vue中transition動畫使用(移動端頁面切換左右滑動效果)

    這篇文章主要介紹了vue中transition動畫使用(移動端頁面切換左右滑動效果),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • 詳解vue-property-decorator使用手冊

    詳解vue-property-decorator使用手冊

    這篇文章主要介紹了vue-property-decorator使用手冊,文中較詳細(xì)的給大家介紹了他們的用法,通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-07-07
  • 用Vue.js方法創(chuàng)建模板并使用多個模板合成

    用Vue.js方法創(chuàng)建模板并使用多個模板合成

    在本篇文章中小編給大家分享了關(guān)于如何使用Vue.js方法創(chuàng)建模板并使用多個模板合成的相關(guān)知識點(diǎn)內(nèi)容,需要的朋友們學(xué)習(xí)下。
    2019-06-06
  • 一文帶你掌握Vue中的路由守衛(wèi)

    一文帶你掌握Vue中的路由守衛(wèi)

    路由守衛(wèi)(Route?Guards)是?Vue?Router?的一個功能,它允許我們在路由發(fā)生之前執(zhí)行邏輯判斷,這篇文章主要為大家介紹了Vue中路由守衛(wèi)的具體應(yīng)用,需要的可以了解下
    2024-03-03
  • Vue結(jié)合高德地圖實(shí)現(xiàn)HTML寫自定義信息彈窗全過程

    Vue結(jié)合高德地圖實(shí)現(xiàn)HTML寫自定義信息彈窗全過程

    最近開發(fā)中遇到一個多個點(diǎn)繪制,并實(shí)現(xiàn)點(diǎn)擊事件,出現(xiàn)自定義窗口顯示相關(guān)信息等功能,下面這篇文章主要給大家介紹了關(guān)于Vue結(jié)合高德地圖實(shí)現(xiàn)HTML寫自定義信息彈窗的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • vue input 輸入校驗(yàn)字母數(shù)字組合且長度小于30的實(shí)現(xiàn)代碼

    vue input 輸入校驗(yàn)字母數(shù)字組合且長度小于30的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue input 校驗(yàn)字母數(shù)字組合且長度小于30的實(shí)現(xiàn)代碼,文章給大家補(bǔ)充介紹了在Vue.Js下使用el-input框只能輸入數(shù)字并限制位數(shù)并且限制中文輸入以及粘貼功能,感興趣的朋友跟隨腳本之家小編一起看看吧
    2018-05-05
  • Vue圖片裁剪組件實(shí)例代碼

    Vue圖片裁剪組件實(shí)例代碼

    這篇文章主要給大家介紹了關(guān)于Vue圖片裁剪組件的相關(guān)資料,本文介紹的組件是基于vue-cropper二次封裝,vue-cropper大家應(yīng)該都很熟悉了吧,需要的朋友可以參考下
    2021-07-07

最新評論