vue 弹窗 模板

html 复制代码
<template>
    <el-dialog
      title="选择批号"
      :visible.sync="showFlag"
      width="800px"
      append-to-body
      :destroy-on-close="true"
      @open="handleOpen"
    >
      <el-form :model="queryParams" ref="queryForm" :inline="true">
        <el-form-item label="规格" prop="specs">
          <el-input v-model="queryParams.specs" placeholder="请输入规格" clearable size="small"/>
        </el-form-item>
    
        <el-form-item label="品名" prop="itemInfo_ItemName">
          <el-input v-model="queryParams.itemInfo_ItemName" placeholder="请输入料品名称" clearable size="small"/>
        </el-form-item>
        <el-form-item>
          <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
          <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
        </el-form-item>
      </el-form>
  
      <el-table 
        v-loading="loading" 
        :data="binList" 
        @selection-change="handleSelectionChange"
        @row-dblclick="handleRowDbClick">
        <el-table-column type="selection" width="55" />
        <el-table-column label="行号" align="center" prop="docLineNo" />
        <el-table-column label="品名" align="center" prop="itemInfo_ItemName" />
        <el-table-column label="规格" align="center" prop="specs" />
        <el-table-column label="可退货数量" align="center" prop="applyQtyTU1" />
        <el-table-column label="批号" align="center" prop="lotInfo_LotCode" />
        <el-table-column label="番号" align="center" prop="seiBanCode" />
      </el-table>
  
      <pagination
        v-show="total>0"
        :total="total"
        :page.sync="queryParams.pageNum"
        :limit.sync="queryParams.pageSize"
        @pagination="getList"
      />
  
      <div slot="footer" class="dialog-footer">
        <el-button type="primary" @click="confirmSelect">确 定</el-button>
        <el-button @click="cancel">取 消</el-button>
      </div>
    </el-dialog>
  </template>
  
  <script>

  import {   getListReturnDataByReceipt3 } from "@/api/mes/xs/salesreturnreceipt";



  export default {
    name: "BinSelect",
    data() {
      return {
        docLineRemainingQty: new Map(),
        showFlag: false,
        loading: false,
        selectedRows: [],
        total: 0,
        binList: [],
        queryParams: {
          pageNum: 1,
          pageSize: 10,
          docNo:null,
          itemInfo_ItemName: null, //料品名称
          specs:null, //规格
          // applyQtyTU1:null, //可退货数量
          // lotInfo_LotCode:null, //批号
          // seiBanCode:null, //番号
        }
      };
    },
    methods: {
      handleOpen() {
        console.log('Dialog opened, showFlag:', this.showFlag);
      },
      getList() {
        this.loading = true;
      
        getListReturnDataByReceipt3(this.queryParams).then(response => {
          this.binList = response.rows;
          this.binList.forEach(item => {
            const remainingQty = this.docLineRemainingQty.get(item.itemInfo_ItemCode) || 0;
            item.applyQtyTU1 = remainingQty; // Assign the remaining quantity to the item
          });
          console.log(this.binList);
          this.total = response.total;
          this.loading = false;
        });
      },
      handleQuery() {
        this.queryParams.pageNum = 1;
        this.getList();
      },
      resetQuery() {
        this.resetForm("queryForm");
        this.handleQuery();
      },
      handleSelectionChange(selection) {
        this.selectedRows = selection;
      },
      handleRowDbClick(row) {
        if (this.$refs.table) {
            this.$refs.table.toggleRowSelection(row);
        } else {
            console.error("表格引用未定义");
        }
      },
      confirmSelect() {
        if (this.selectedRows.length > 0) {
          this.$emit('onSelected', this.selectedRows);
          this.cancel();
        } else {
          this.$message.warning('请至少选择一条数据');
        }
      },
      cancel() {
        this.showFlag = false;
        this.selectedRows = [];
      }
    }
  };
  </script>
    
html 复制代码
      <el-col :span="1.5">
            <el-button 
                type="primary" 
                icon="el-icon-plus" 
                size="mini" 
                @click="handleQueryReturnDataByReceipt"
                :disabled="!form.returnOrderId"
                v-hasPermi="['mes/xs:salesreturnreceipt:add']"
            >配件选择</el-button>
          </el-col>
          <ReturnDataByReceipt ref="ReturnDataByReceipt" @onSelected="onReturnDataByReceiptSelected" :size="'large'"></ReturnDataByReceipt>
         
          <el-col :span="1.5">

效果

html 复制代码
 onReturnDataByReceiptSelected(selected){}
     
相关推荐
hy_花花3 分钟前
Vue3.4之defineModel的用法
前端·vue.js
我是仙女你信不信24 分钟前
生成pdf并下载
前端·javascript·vue.js
vvilkim1 小时前
React 组件类型详解:类组件 vs. 函数组件
前端·javascript·react.js
啊吧啊吧曾小白1 小时前
作用域、闭包与this指向问题
前端·javascript·面试
HiF1 小时前
Hexo博客集成LivePhoto
javascript
八了个戒2 小时前
「数据可视化 D3系列」入门第七章:坐标轴的使用
前端·javascript·数据可视化·canvas·d3
八了个戒2 小时前
「数据可视化 D3系列」入门第二章:选择器与数据绑定
前端·javascript·数据可视化·canvas·d3
周星星日记2 小时前
12.vue3中组件实现原理(下)之emit和slots
前端·vue.js·面试
dsl_12 小时前
axios重复请求解决方案
前端·javascript·axios
拾荒旧痕2 小时前
通过gird布局实现div的响应式分布排列
前端·javascript·css