RoleSelect.vue 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. <template>
  2. <el-select
  3. v-model="selected"
  4. class="size-select"
  5. placeholder="请选择"
  6. @change="select"
  7. :style="styles"
  8. :multiple="multiple"
  9. clearable
  10. >
  11. <el-option
  12. v-for="item in optionList"
  13. :key="item.roleCode"
  14. :label="item.roleName"
  15. :value="item.roleCode"
  16. >
  17. <span>{{ item.roleName }}</span>
  18. </el-option>
  19. </el-select>
  20. </template>
  21. <script>
  22. export default {
  23. name: "RoleSelect",
  24. props: {
  25. value: [String, Array],
  26. multiple: Boolean,
  27. styles: { type: String },
  28. },
  29. data() {
  30. return {
  31. optionList: [],
  32. selected: "",
  33. };
  34. },
  35. async created() {
  36. const res = await this.$http.post("/api/admin/sys/role/query");
  37. // console.log(res.data);
  38. this.optionList = res.data.data;
  39. },
  40. watch: {
  41. value: {
  42. immediate: true,
  43. handler(val) {
  44. this.selected = val;
  45. },
  46. },
  47. },
  48. methods: {
  49. select() {
  50. this.$emit("input", this.selected);
  51. this.$emit("change", this.selected);
  52. },
  53. },
  54. };
  55. </script>
  56. <style></style>