组件上的v-model(以封装频道组件为例)

210 阅读1分钟

原理:其实是 自定义属性value 和 自定义事件input 的快捷使用。

目的:  这是一个多次出现的组件,因为在项目中多次出现,故对其进行封装,减少代码量功能

功能: 1. 自主发ajax请求,获取数据列表,显示在列表中

         2. 给父组件(使用它的那个组件)回传用户选中的频道id(给调用组件的地方返回选中的频道id )==> 典型的子传父$emit

格式:

// 父组件
data: { return { channel_id: ''}}

// 1\. 使用。 在子组件使用v-model。与在普通表单元素上使用是一样的。
<my-channels v-model="channel_id"></my-channels>
// 2\. 在子组件my-channels的内部:
//  (1)  设置一个名为value的属性来获取从父组件传的v-model的初值
//   (2)  在某个时间点,触发名为input的事件,来修改父组件中v-model的值

创建组件:MyChannelsVmodel.vue

<template>
   <!-- 由于它的根元素是el-form-item,则在使用这个组件时,要用el-form包起来 -->
   <el-form-item label="频道">
    <!-- clearable: 表示可清空的单选 -->

    <!--
      change 事件是由el-select组件提供的,当用户的选择发生变化时,它会触发,并传入当前
      用户选中的值
     -->
    <el-select @change="hSelectChange"  v-model="channelId" clearable placeholder="请选择频道">
      <el-option
      v-for="channel in channels"
      :key="channel.id"
      :label="channel.name"
      :value="channel.id"></el-option>
    </el-select>
  </el-form-item>
</template>

<script>
// 引入方法,发请求,取回数据给channels
import { getArticleChannels } from '@/api/article'

export default {
  name: 'MyChannelsVmodel',
  props: ['value'],
  data () {
    return {
      channelId: '', // 当前选中频道
      channels: [] // 频道列表
    }
  },
  computed: { },
  async created () {
    const result = await getArticleChannels()
    console.log('loadChannels', result)
    this.channels = result.data.data.channels
  },
  // created () {
  //   this.loadChannels()
  // },
  methods: {
    hSelectChange (val) {
      // console.log('hSelectChange', val)
      // 抛出事件给父组件
      // this.$emit(事件名,参数)

      // 事件名input是一个特殊的名字,它会把val值直接设置给父组件中v-model后设置的数据项
      this.$emit('input', val)
    }
  }
}
</script>