StateSelect.vue 985 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. <template>
  2. <el-select
  3. v-model="selected"
  4. class="size-select"
  5. placeholder="请选择"
  6. @change="select"
  7. style="width: 100px;"
  8. >
  9. <el-option
  10. v-for="item in optionList"
  11. :key="item.code"
  12. :label="item.name"
  13. :value="item.code"
  14. >
  15. <span>{{ item.name }}</span>
  16. </el-option>
  17. </el-select>
  18. </template>
  19. <script>
  20. export default {
  21. name: "StateSelect",
  22. props: {
  23. value: {
  24. type: String,
  25. default: "",
  26. },
  27. },
  28. data() {
  29. return {
  30. optionList: [
  31. { code: "0", name: "禁用" },
  32. { code: "1", name: "启用" },
  33. ],
  34. selected: "",
  35. };
  36. },
  37. async created() {},
  38. watch: {
  39. value: {
  40. immediate: true,
  41. handler(val, oldVal) {
  42. console.log({ val, oldVal });
  43. this.selected = val;
  44. },
  45. },
  46. },
  47. methods: {
  48. select() {
  49. this.$emit("input", this.selected);
  50. this.$emit("change", this.selected);
  51. },
  52. },
  53. };
  54. </script>
  55. <style></style>