vue提交select下拉框选中的值

简介: vue提交select下拉框选中的值

例子

<template>
  <div class="tab-container">
    <div class="filter-container" style="margin-bottom: 20px">
      <el-form
        :model="questionForm"
        ref="dataForm"
        label-position="left"
        label-width="90px"
        style="width: 400px; margin-left: 50px"
      >
        <el-form-item label="用户名" prop="userName">
          <el-input
            v-model="questionForm.userName"
            placeholder="请输入角色名称"
          />
        </el-form-item>
        <el-form-item label="昵称" prop="realName">
          <el-input v-model="questionForm.realName" placeholder="请输入昵称" />
        </el-form-item>
        <el-form-item label="部门">
          <el-select
            v-model="questionForm.organId"
            placeholder="请选择"
            style="width: 100%"
            @change="changeHandler"
          >
            <el-option
              v-for="item in getOrganList"
              :key="item.id"
              :label="item.organName"
              :value="item.id"
            >
            </el-option>
          </el-select>
        </el-form-item>
      </el-form>
      <div slot="footer" class="dialog-footer">
        <el-button type="primary" @click="createData()">确定</el-button>
      </div>
    </div>
  </div>
</template>
<script>
//调用接口
// import { getOrgan } from "@/api/alarm/query";
export default {
  data() {
    return {
      questionForm: {
        userName: "",
        realName: "",
        organName: "",
        organId: "",
      },
      getOrganList: [],
    };
  },
  created() {
    //加载部门
    this.getOrgan();
  },
  methods: {
    changeHandler(value) {
      const checkedItem = this.getOrganList.find((a) => a.id === value);
      this.questionForm.organName = checkedItem.organName;
    },
    //获取部门信息接口定义
    getOrgan() {
      const params = {
        organId: 1,
        authority: 1,
      };
      import("./mock").then((res) => {
        this.getOrganList = res.data.organs;
      });
    },
    //添加用户
    async createData() {
      const params =this.questionForm;
      alert(JSON.stringify(params));
    },
  },
};
</script>
<style scoped>
.tab-container {
  margin: 30px;
}
</style>

json

{
    "msg": "success",
    "code": 1,
    "data": {
        "organs": [
            {
                "id": 1,
                "organName": "部门1"
            },
            {
                "id": 2,
                "organName": "部门2"
            },
            {
                "id": 3,
                "organName": "部门3"
            },
            {
                "id": 4,
                "organName": "部门4"
            },
            {
                "id": 5,
                "organName": "部门5"
            },
            {
                "id": 6,
                "organName": "部门6"
            },
            {
                "id": 7,
                "organName": "部门7"
            },
            {
                "id": 8,
                "organName": "部门8"
            }
        ]
    }
}

相关文章
|
1天前
|
JavaScript
VUE里的find与filter使用与区别
VUE里的find与filter使用与区别
20 0
|
1天前
|
JavaScript
vue页面加载时同时请求两个接口
vue页面加载时同时请求两个接口
|
1天前
|
JavaScript
vue里样式不起作用的方法,可以通过deep穿透的方式
vue里样式不起作用的方法,可以通过deep穿透的方式
14 0
|
1天前
|
移动开发 JavaScript 应用服务中间件
vue打包部署问题
Vue项目`vue.config.js`中,`publicPath`设定为&quot;/h5/party/pc/&quot;,在线环境基于打包后的`dist`目录,而非Linux的`/root`。Nginx代理配置位于`/usr/local/nginx/nginx-1.13.7/conf`,包含两个相关配置图。
vue打包部署问题
|
1天前
|
JavaScript 前端开发
iconfont 图标在vue里的使用
iconfont 图标在vue里的使用
17 0
|
1天前
|
存储 JavaScript
Vue当前时间与接口返回时间的判断
Vue当前时间与接口返回时间的判断
14 0
|
1天前
|
JavaScript 前端开发
Vue生成Canvas二维码
Vue生成Canvas二维码
12 0
|
1天前
|
JavaScript 前端开发 开发者
new Vue() 发生了什么
new Vue() 发生了什么
11 1
|
1天前
|
JavaScript
vue打印v-model 的值
vue打印v-model 的值
|
1天前
|
JavaScript
Vue实战-组件通信
Vue实战-组件通信
7 0