el-select下拉选择图片,并且回显图片

在这里插入图片描述
回显图片有两种方法
第一种是通过ref给input框添加样式

           <el-select
                v-model="addForm.appPic"
                size="medium"
                placeholder="请选择应用图标"
                filterable
                @change="changeSelection"
                ref="select"
              >
                <el-option
                  v-for="item in iconList"
                  :key="item.iconId"
                  :label="item.iconName"
                  :value="item.iconId"
                >
                  <template>
                    <!-- elementui 的flex布局 -->
                    <el-row type="flex" :gutter="20" justify="center">
                      <el-col :span="4">
                        <img
                          :src="'/sp/icon/' + item.iconId + '.png'"
                          alt=""
                          width="30px"
                          height="30px"
                        />
                      </el-col>
                      <el-col :span="16">
                        <span>{{ item.iconName }}</span>
                      </el-col>
                    </el-row>
                  </template>
                </el-option>
              </el-select>        
    changeSelection(val) {
      for (let index in this.iconList) {
        let obj = this.iconList[index];
        if (obj.iconId == val) {
          this.$refs["select"].$el.children[0].children[0].setAttribute(
            "style",
            `background: url(${"/sp/icon/" + obj.iconId + ".png"}) no-repeat;
            width: 25px; height: 25px;
            border: none;
            background-position: 80% center;
            background-size:65%`
          );
        }
      }
    },

//关闭弹框时去除样式
this.$refs["select"].$el.children[0].children[0].removeAttribute("style");

但是这种方法在el-table中失效,ref也是动态生成添加唯一标识也不管用
在这里插入图片描述
在这里插入图片描述
第二种是自定义一个img来展示图片,定位到input框上,并去掉input的边框
在这里插入图片描述

//css
.picDiv {
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  position: relative;
  .imgDiv {
    width: 37px;
    height: 37px;
    position: absolute;
    left: 0;
    top: 0;
  }
  /deep/ .el-input__inner {
    background-color: transparent;
    border: none;
    text-indent: -9999px;
  }
}

在表格中的运用也是好的
在这里插入图片描述

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值