el-select下拉框 change事件返回该项所有数据

主要代码 value-key

<template>
  <div>
    <el-select
      v-model="value"
      value-key="label"
      placeholder="请选择"
      @change="selectChange"
    >
      <el-option
        v-for="item in options"
        :key="item.label"
        :label="item.label"
        :value="item"
      >
      </el-option>
    </el-select>
  </div>
</template>

<script>
export default {
  data() {
    return {
      options: [
        {
          value: "选项1",
          label: "黄金糕",
        },
        {
          value: "选项2",
          label: "双皮奶",
        },
        {
          value: "选项3",
          label: "蚵仔煎",
        },
        {
          value: "选项4",
          label: "龙须面",
        },
        {
          value: "选项5",
          label: "北京烤鸭",
        },
      ],
      value: "",
    };
  },
  mounted() {},
  methods: {
    selectChange(item) {
      console.log(item);
    },
  },
};
</script>

<style scoped></style>

以下暂时自行理解,需与后端对接(有时间在整理)。。。。。

1. input 远程搜索
 <el-autocomplete
                style="width: 100%"
                v-model="form.ENTNAME"
                :fetch-suggestions="querySearchAsync"
                placeholder="企业名称"
                @select="handleSelect"
                clearable
                value-key="ENTAME"
              >
              </el-autocomplete>

 querySearchAsync(query, callBack) {
      if (query!== "") {
        this.$http
          .post("/system/ssoloin/getUrlataMap", {
            method: "getEntByword",
            token: getToken(),
            mapData: { type: "0", keyword: query},
          })
          .then((res) => {
            callBack(res.data.data.RESULTDATA);
          });
      }
    },

    handleSelect(item) {
      this.$http
        .post("/syem/ssolon/getUrltap", {
          method: "getRegistnfo",
          token: getToken(),
          mapData: { type: "0", keyWord: item.ENTNAME },
        })
        .then((res) => {
          this.form = res.data.data.RESTDATA[0];
        });
    },

2. select 远程搜索

<el-select
                v-model="form.ENTNAME"
                filterable
                remote
                reserve-keyword
                placeholder="请输入企业名称"
                :remote-method="remoteMethod"
                :loading="loading"
                style="width: 100%"
                @change="selectChange"
              >
                <el-option
                  v-for="(item, index) in options"
                  :key="index"
                  :label="item.ENTNAME"
                  :value="item.ENTNAME"
                >
                </el-option>
              </el-select>

    remoteMethod(query) {
      if (query !== "") {
        this.loading = true;
        this.$http
          .post("/syst/ssgin/getUrlaMap", {
            method: "getEyKeyord",
            token: getToken(),
            mapData: { type: "0", keyword: query },
          })
          .then((res) => {
            this.loading = false;

            this.options = res.data.data.RESUDTA;
          });
      } else {
        this.options = [];
      }
    },

 selectChange(value) {
      this.$http
        .post("/syem/ssogin/getUrlDaMap", {
          method: "getRegierInfo",
          token: getToken(),
          mapData: { type: "0", keyWord: value},
        })
        .then((res) => {
          this.form = res.data.data.RESULATA[0];
        });
    },
相关推荐
luoluoal几秒前
java项目之基于spring boot的多维分类的知识管理系统的设计与实现源码
java·开发语言·vue.js·spring boot·源码
LvManBa2 分钟前
HTML5中新增元素介绍
前端·html·html5
程序员阿龙25 分钟前
计算机毕业设计之:基于uni-app的校园活动信息共享系统设计与实现(三端开发,安卓前端+网站前端+网站后端)
前端·uni-app·移动端开发·校园应用开发·实时信息共享·信息系统设计与实现·校园活动管理
好青崧44 分钟前
JavaScript 中的日期与时间处理
javascript
shangtaobocdns1 小时前
django+vue
vue.js·python·django
天蓝蓝235281 小时前
Vue.js与Flask/Django后端配合
vue.js·django·flask
让开,我要吃人了1 小时前
HarmonyOS鸿蒙开发实战(5.0)表情图片聊天案例实践
前端·华为·移动开发·harmonyos·鸿蒙·harmonyos next·鸿蒙开发
Java Fans1 小时前
JavaScript网页设计案例(动态表单、实时搜索、交互式地图、无限滚动加载等)
javascript
GISer_Jing1 小时前
Vue.js与Flask/Django后端配合
vue.js·django
笃励3 小时前
Angular面试题二
前端·javascript·angular.js