index.vue 1.1 KB
<template>
  <el-select v-model="activeMediaCode" placeholder="请选择媒体" size="small">
    <el-option v-for="item in mediaOptions" :key="item.code" :label="item.value" :value="item.code"></el-option>
  </el-select>
</template>

<script>
import { queryMediaCodes } from "@/api/dashboard/";

export default {
  name: "MediaSelect",
  props: {
    value: {
      type: String,
      default: ""
    }
  },
  data() {
    return {
      mediaOptions: [
        // {
        //   value: "toutiao",
        //   label: "头条"
        // },
        // {
        //   value: "gdt",
        //   label: "广点通"
        // }
      ],
      activeMediaCode: ""
    };
  },
  watch: {
    value: {
      immediate: true,
      handler(val) {
        this.activeMediaCode = val;
      }
    },
    activeMediaCode(val) {
      this.$emit("input", val);
    }
  },
  created() {
    this.queryMediaCode();
  },
  methods: {
    queryMediaCode() {
      queryMediaCodes()
        .then(res => {
          this.mediaOptions = res.data;
        })
        .catch(() => {});
    }
  }
};
</script>

<style lang="scss" scoped>
</style>