vue实现网格弹窗(每个网格都是一个下拉)

vue实现网格弹窗(每个网格都是一个下拉)

在操作中点击图像标记,触发点击事件

html 复制代码
<el-table-column align="center" label="操作" width="260">
           <el-button
              v-if="hasPerm('goods-menu')"
              slot="reference"
              size="mini"
              type="primary"
              @click="handleShowLabel(scope.row)"
              >图像标记</el-button
            >
          </template>
        </el-table-column>
      </el-table>
 <el-dialog :visible.sync="imgLabelVisible" top="3vh" width="90vw" title="选择饮料">
      <div class="dialog-content">
        <div class="left-pane">
          <img :src="currentImgUrl" style="width:400px;margin:auto"   alt="左侧图片" />
        </div>
        <div class="right-pane">
          <el-table :data="gridData" style="width: 100%" border >
            <el-table-column prop="row" label="行号/列号" width = 60px>
              <template slot-scope="scope">
                <span>{{ scope.$index + 1 }}</span>
              </template>
            </el-table-column>

            <el-table-column prop="col" label="1">
              <template slot-scope="scope">
                <el-select v-model="scope.row.row1.goodsId" filterable clearable @change="selectChange" placeholder="请选择饮料">
                  <el-option v-for="drink in drinkOptions"
                             :key="drink.value"
                             :label="drink.label"
                             :value="drink.value"></el-option>
                </el-select>
              </template>
            </el-table-column>
            <el-table-column prop="col" label="2">
            <template slot-scope="scope">
              <el-select v-model="scope.row.row2.goodsId" filterable clearable @change="selectChange" placeholder="请选择饮料">
                <el-option v-for="drink in drinkOptions"
                           :key="drink.value"
                           :label="drink.label"
                           :value="drink.value"></el-option>
              </el-select>
            </template>
          </el-table-column>
            <el-table-column prop="col" label="3">
              <template slot-scope="scope">
                <el-select v-model="scope.row.row3.goodsId" filterable clearable @change="selectChange" placeholder="请选择饮料">
                  <el-option v-for="drink in drinkOptions"
                             :key="drink.value"
                             :label="drink.label"
                             :value="drink.value"></el-option>
                </el-select>
              </template>
            </el-table-column><el-table-column prop="col" label="4">
            <template slot-scope="scope">
              <el-select v-model="scope.row.row4.goodsId" filterable clearable @change="selectChange" placeholder="请选择饮料">
                <el-option v-for="drink in drinkOptions"
                           :key="drink.value"
                           :label="drink.label"
                           :value="drink.value"></el-option>
              </el-select>
            </template>
          </el-table-column><el-table-column prop="col" label="5">
            <template slot-scope="scope">
              <el-select v-model="scope.row.row5.goodsId" filterable clearable @change="selectChange" placeholder="请选择饮料">
                <el-option v-for="drink in drinkOptions"
                           :key="drink.value"
                           :label="drink.label"
                           :value="drink.value"></el-option>
              </el-select>
            </template>
          </el-table-column><el-table-column prop="col" label="6">
            <template slot-scope="scope">
              <el-select v-model="scope.row.row6.goodsId" filterable clearable @change="selectChange" placeholder="请选择饮料">
                <el-option v-for="drink in drinkOptions"
                           :key="drink.value"
                           :label="drink.label"
                           :value="drink.value"></el-option>
              </el-select>
            </template>
          </el-table-column><el-table-column prop="col" label="7">
            <template slot-scope="scope">
              <el-select v-model="scope.row.row7.goodsId" filterable clearable @change="selectChange" placeholder="请选择饮料">
                <el-option v-for="drink in drinkOptions"
                           :key="drink.value"
                           :label="drink.label"
                           :value="drink.value"></el-option>
              </el-select>
            </template>
          </el-table-column><el-table-column prop="col" label="8">
            <template slot-scope="scope">
              <el-select v-model="scope.row.row8.goodsId" filterable clearable @change="selectChange" placeholder="请选择饮料">
                <el-option v-for="drink in drinkOptions"
                           :key="drink.value"
                           :label="drink.label"
                           :value="drink.value"></el-option>
              </el-select>
            </template>
          </el-table-column>
<!--            <el-table-column label="饮料选择">-->
<!--              <template slot-scope="scope">-->
<!--                <el-select v-model="scope.row.selectedDrink" placeholder="请选择饮料">-->
<!--                  <el-option v-for="drink in drinkOptions"-->
<!--                             :key="drink.value"-->
<!--                             :label="drink.label"-->
<!--                             :value="drink.value"></el-option>-->
<!--                </el-select>-->
<!--              </template>-->
<!--            </el-table-column>-->
          </el-table>
        </div>
      </div>
      <span slot="footer" class="dialog-footer">
      <el-button @click="imgLabelVisible = false">取 消</el-button>
      <el-button type="primary" @click="saveSelection">确 定</el-button>
    </span>
    </el-dialog>


export default {
  data() {
    return {
      gridData: [{
        row1:{
          row:1,
          col:1,
          goodsId:null,
        },
        row2:{
          row:1,
          col:2,
          goodsId:null,
        },
        row3:{
          row:1,
          col:3,
          goodsId:null,
        },
        row4:{
          row:1,
          col:4,
          goodsId:null,
        },
        row5:{
          row:1,
          col:5,
          goodsId:null,
        },
        row6:{
          row:1,
          col:6,
          goodsId:null,
        },
        row7:{
          row:1,
          col:7,
          goodsId:null,
        },
        row8:{
          row:1,
          col:8,
          goodsId:null,
        },
      },{
        row1:{
          row:2,
          col:1,
          goodsId:null,
        },
        row2:{
          row:2,
          col:2,
          goodsId:null,
        },
        row3:{
          row:2,
          col:3,
          goodsId:null,
        },
        row4:{
          row:2,
          col:4,
          goodsId:null,
        },
        row5:{
          row:2,
          col:5,
          goodsId:null,
        },
        row6:{
          row:2,
          col:6,
          goodsId:null,
        },
        row7:{
          row:2,
          col:7,
          goodsId:null,
        },
        row8:{
          row:2,
          col:8,
          goodsId:null,
        },
      },{
        row1:{
          row:3,
          col:1,
          goodsId:null,
        },
        row2:{
          row:3,
          col:2,
          goodsId:null,
        },
        row3:{
          row:3,
          col:3,
          goodsId:null,
        },
        row4:{
          row:3,
          col:4,
          goodsId:null,
        },
        row5:{
          row:3,
          col:5,
          goodsId:null,
        },
        row6:{
          row:3,
          col:6,
          goodsId:null,
        },
        row7:{
          row:3,
          col:7,
          goodsId:null,
        },
        row8:{
          row:3,
          col:8,
          goodsId:null,
        },
      },{
        row1:{
          row:4,
          col:1,
          goodsId:null,
        },
        row2:{
          row:4,
          col:2,
          goodsId:null,
        },
        row3:{
          row:4,
          col:3,
          goodsId:null,
        },
        row4:{
          row:4,
          col:4,
          goodsId:null,
        },
        row5:{
          row:4,
          col:5,
          goodsId:null,
        },
        row6:{
          row:4,
          col:6,
          goodsId:null,
        },
        row7:{
          row:4,
          col:7,
          goodsId:null,
        },
        row8:{
          row:4,
          col:8,
          goodsId:null,
        },
      },{
        row1:{
          row:5,
          col:1,
          goodsId:null,
        },
        row2:{
          row:5,
          col:2,
          goodsId:null,
        },
        row3:{
          row:5,
          col:3,
          goodsId:null,
        },
        row4:{
          row:5,
          col:4,
          goodsId:null,
        },
        row5:{
          row:5,
          col:5,
          goodsId:null,
        },
        row6:{
          row:5,
          col:6,
          goodsId:null,
        },
        row7:{
          row:5,
          col:7,
          goodsId:null,
        },
        row8:{
          row:5,
          col:8,
          goodsId:null,
        },
      },{
        row1:{
          row:6,
          col:1,
          goodsId:null,
        },
        row2:{
          row:6,
          col:2,
          goodsId:null,
        },
        row3:{
          row:6,
          col:3,
          goodsId:null,
        },
        row4:{
          row:6,
          col:4,
          goodsId:null,
        },
        row5:{
          row:6,
          col:5,
          goodsId:null,
        },
        row6:{
          row:6,
          col:6,
          goodsId:null,
        },
        row7:{
          row:6,
          col:7,
          goodsId:null,
        },
        row8:{
          row:6,
          col:8,
          goodsId:null,
        },
      }
      ],
}
}
}
 methods: {
     handleShowLabel(row) {
      this.imgLabelVisible = true;
      this.currentImgId = row.imageRecordId
      this.currentImgUrl = row.imageUrl;
      // TODO 改成根据后台数据回填
      for(var i =0; i < this.gridData.length; i++){
        this.gridData[i].row1.goodsId = null;
        this.gridData[i].row2.goodsId = null
        this.gridData[i].row3.goodsId = null
        this.gridData[i].row4.goodsId = null
        this.gridData[i].row5.goodsId = null
        this.gridData[i].row6.goodsId = null
        this.gridData[i].row7.goodsId = null
        this.gridData[i].row8.goodsId = null
      }
      
    },
    saveSelection() {
      // Handle saving the user's selections
      const cabinetGoodsList = []
      console.log('User selections:', this.gridData);
      for (let i = 0; i < this.gridData.length; i++) {
        for (let j = 1; j <= 8; j++) {
          const g = this.gridData[i][`row${j}`]
          cabinetGoodsList.push({levelNo:g.row, channelNo:g.col,goodsId:g.goodsId})
          // console.log(this.gridData[i][`row${j}`].goodsId)
        }
      }
      this.goodsData.imageRecordId = this.currentImgId;
      this.goodsData.cabinetGoodsList = cabinetGoodsList;
    
      this.cabinetGoods(this.goodsData);
      console.log(this.goodsData)
    },
    cabinetGoods(goodsData) {
      saveCabinetGoodsAPI(goodsData).then(res => {
        this.$notify({
          message: "操作成功",
          type: "success",
          duration: 2000,
          offset: 80,
        });
        this.imgVisible = false
      })
    },
}

请求后台

export function saveCabinetGoodsAPI(data) {

return fetch({

url: /api/cjd/manual_data/cabinet_goods,

method: 'post',

data

});

}

相关推荐
杨荧13 分钟前
【JAVA开源】基于Vue和SpringBoot的洗衣店订单管理系统
java·开发语言·vue.js·spring boot·spring cloud·开源
l1x1n021 分钟前
No.3 笔记 | Web安全基础:Web1.0 - 3.0 发展史
前端·http·html
Q_w774226 分钟前
一个真实可用的登录界面!
javascript·mysql·php·html5·网站登录
昨天;明天。今天。37 分钟前
案例-任务清单
前端·javascript·css
一丝晨光1 小时前
C++、Ruby和JavaScript
java·开发语言·javascript·c++·python·c·ruby
Front思1 小时前
vue使用高德地图
javascript·vue.js·ecmascript
zqx_72 小时前
随记 前端框架React的初步认识
前端·react.js·前端框架
惜.己2 小时前
javaScript基础(8个案例+代码+效果图)
开发语言·前端·javascript·vscode·css3·html5
什么鬼昵称2 小时前
Pikachu-csrf-CSRF(get)
前端·csrf
长天一色3 小时前
【ECMAScript 从入门到进阶教程】第三部分:高级主题(高级函数与范式,元编程,正则表达式,性能优化)
服务器·开发语言·前端·javascript·性能优化·ecmascript