Elementui el-input 實現自定義 v-model

Vue 本身支持自定義組件實現 v-model ,但 el-input 作為 Elementui 的自定義組件也已經實現 v-model ,那么如果在自定義組件中使用 el-input ,但自定義組件也想實現 v-model ,應該怎么做?

更多精彩

錯誤的方式

  1. Vue 中讓自定義組件實現 v-model 可參考 Vue自定義v-model
  2. 但如果按照這種方式想要讓以下代碼實現 v-model ,是不可取的
    • 可以用,但每次在頁面第一次渲染的時候都沒有值,非要手動輸入一次,才會觸發變化
    • 這是因為下面這個 in-player 組件中的 el-input 已經實現了自定義的 v-model ,當 in-player 再次通過同樣的方式實現時,就出現了兩次 watch 操作
<template>
  <div class="in-player-panel">
    <el-input placeholder="請輸入視頻vid" v-model="videoId">
      <el-button slot="append" @click="changePlayAuth">播放</el-button>
    </el-input>
  </div>
</template>

<script type="text/ecmascript-6">
  export default {
    name: 'in-player',
    props: {
      value: {
        type: String,
        value: ' '
      }
    },
    data () {
      return {
        videoId: ''
      }
    },
    watch: {
      'value' (val) {
        if (val == this.videoId) { return false }
        this.videoId = val
      },
      'videoId' (val) { this.$emit('input', val) }
    }
  }
</script>

正確的方式

  1. 如果在自定義組件中,既想使用 el-input 的樣式和規則,又想讓組件本身實現自定義 v-model
  2. 那么就應該像如下代碼一樣,不直接使用 el-input 的 v-model 實現,轉而使用其 @input 函數
<template>
  <div class="in-player-panel">
    <el-input placeholder="請輸入視頻vid" :value="value" @input="update">
      <el-button slot="append" @click="changePlayAuth">播放</el-button>
    </el-input>
  </div>
</template>

<script type="text/ecmascript-6">
  export default {
    name: 'in-player',
    props: {
      value: {
        type: String,
        value: ' '
      }
    },
    methods: {
      update (val) {
        this.$emit('input', val)
      }
    }
  }
</script>
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • Vue 實例 屬性和方法 每個 Vue 實例都會代理其 data 對象里所有的屬性:var data = { a:...
    云之外閱讀 2,245評論 0 6
  • 主要還是自己看的,所有內容來自官方文檔。 介紹 Vue.js 是什么 Vue (讀音 /vju?/,類似于 vie...
    Leonzai閱讀 3,384評論 0 25
  • 深入響應式 追蹤變化: 把普通js對象傳給Vue實例的data選項,Vue將使用Object.defineProp...
    冥冥2017閱讀 4,899評論 6 16
  • 目標:1、了解v-model的本質。2、了解v-model的實現原理。 我們知道Vue的核心特性之一是雙向綁定,v...
    LoveBugs_King閱讀 222,511評論 3 38
  • 基于Vue的一些資料 內容 UI組件 開發框架 實用庫 服務端 輔助工具 應用實例 Demo示例 element★...
    嘗了又嘗閱讀 1,187評論 0 1