main.vue 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. <template>
  2. <el-select
  3. v-model="value"
  4. filterable
  5. reserve-keyword
  6. clearable
  7. :size="size || 'medium'"
  8. style="width: 100%"
  9. :placeholder="placeholder || ''"
  10. :disabled="disabled"
  11. :loading="selectLoading"
  12. @change="selectChange"
  13. >
  14. <el-option
  15. v-for="(item, index) in options"
  16. :key="item.id + index + 'spec'"
  17. :label="item.spec_name"
  18. :value="item.id"
  19. :disabled="item.status === '0'"
  20. >
  21. </el-option>
  22. </el-select>
  23. </template>
  24. <script>
  25. import asyncRequest from "@/apis/components/search-spec";
  26. import resToken from "@/mixins/resToken";
  27. export default {
  28. name: "SearchSpec",
  29. mixins: [resToken],
  30. props: [
  31. "size",
  32. "value",
  33. "placeholder",
  34. "isDetail",
  35. "disabled",
  36. "type",
  37. "names",
  38. ],
  39. /**
  40. * 属性集合
  41. * @param {String} size : 组件大小 非必填
  42. * @param {Array} value : 选中值 必填
  43. * @param {String} placeholder : 提示信息 非必填
  44. * @param {Boolean} isDetail : 是否是详情逻辑 必填
  45. * @param {Boolean} disabled : 是否禁用 必填
  46. * @param {String} names : 选中值label 展示详情必填
  47. */
  48. /**
  49. * 事件集合
  50. * @searchChange : 选中值变化调用 抛出选中数据
  51. */
  52. data() {
  53. return {
  54. options: [],
  55. selectLoading: false,
  56. searchName: "",
  57. formValue: {
  58. start: "",
  59. end: "",
  60. creater: "",
  61. status: "",
  62. spec_name: "",
  63. },
  64. };
  65. },
  66. watch: {
  67. // names: function (val, old) {
  68. // // console.log(val, old);
  69. // this.searchName = val;
  70. // if (this.isDetail && this.searchName) {
  71. // this.remoteMethod(this.searchName);
  72. // }
  73. // },
  74. },
  75. mounted() {
  76. this.options = [];
  77. this.selectLoading = false;
  78. this.remoteMethod();
  79. },
  80. methods: {
  81. async selectChange(e) {
  82. let item = {};
  83. if (e) {
  84. item = this.options.find((i) => i.id === e);
  85. }
  86. this.$emit("searchChange", item);
  87. },
  88. //query
  89. async remoteMethod() {
  90. this.selectLoading = true;
  91. this.options = [];
  92. const { code, data, message } = await asyncRequest.list(this.formValue);
  93. if (code === 0) {
  94. this.options = data;
  95. } else if (code >= 100 && code <= 104) {
  96. await this.logout();
  97. } else {
  98. this.$message.warning(message);
  99. }
  100. this.selectLoading = false;
  101. },
  102. },
  103. };
  104. </script>
  105. <style>
  106. </style>