working-procedure-select.vue 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. <template>
  2. <el-select
  3. v-model="selectVal"
  4. filterable
  5. style="width: 100%"
  6. v-bind="$attrs"
  7. v-on="$listeners"
  8. clearable
  9. >
  10. <el-option
  11. v-for="item in dictList"
  12. :key="item.id"
  13. :value="item.id"
  14. :label="item.name"
  15. ></el-option>
  16. </el-select>
  17. </template>
  18. <script>
  19. import producetask from '@/api/technology/production';
  20. export default {
  21. model: {
  22. prop: 'value',
  23. event: 'updateVal'
  24. },
  25. props: {
  26. value: {
  27. type: [String, Number, Array],
  28. default: ''
  29. },
  30. init: {
  31. type: Boolean,
  32. default: true
  33. }
  34. },
  35. data () {
  36. return {
  37. dictList: []
  38. };
  39. },
  40. computed: {
  41. selectVal: {
  42. set (val) {
  43. this.$emit(
  44. 'selfChange',
  45. val,
  46. this.dictList.find((i) => i.id === val)
  47. );
  48. this.$emit('updateVal', val);
  49. },
  50. get () {
  51. return this.value;
  52. }
  53. }
  54. },
  55. created () {
  56. if (this.init) {
  57. this.getList();
  58. }
  59. },
  60. methods: {
  61. async getList () {
  62. const res = await producetask.list({
  63. pageNum: 1,
  64. size: -1
  65. });
  66. this.dictList = res.list;
  67. }
  68. }
  69. };
  70. </script>