Vue中使用el-transfer渲染接口数据

1:最近遇到项目中需要使用elementui–el-transfter穿梭框渲染数据,在此记录如下:

      <el-transfer
        filterable
        :data="transferData" 
        :titles="['左', '右']"
        @change="handleChange"
        @left-check-change="leftCopeChane"
        filter-placeholder="请输入名称"
        v-model="value"
        >
      </el-transfer>
data() {
    return {
      value: [],
      transferData: []
      }
   }
import { data} from "@/api";
 getTransfer() {
      let params = {
        pageNum: 1,
        pageSize: 999,
      };
      assetApInfo(params).then(res => {
          if (res.code == 200) {
            let data = [];
            let allData = res.data.data;
            allData.forEach((item, index) => {
              data.push({
                item,
                id: item.id,
                label: item.name,
                //这里的key值一定要是index,否则目标列表无法显示
                key: index
              });
            });
            // 接口总数据筛选出来的新数组赋值给transferData
            this.transferData = data;
          } else {
            this.$message.error("接口表字段查询失败");
          }
        })
        .catch(error => {
          this.$message.error(error);
        });
     },
     handleChange(value, direction, movedKeys) {
        // console.log(value,'value值');
        // console.log(direction,'22222222222');
        // console.log(movedKeys,'33333333333');
        const tempArr = [];
        value.forEach((key)=>{
          tempArr.push(this.transferData[key].id);
        });
        this.Ids = tempArr;
        //console.log(this.selecedOption,'111111111111111')
        //console.log(this.Ids,'99999999')
     },
     leftCopeChane(selecedOption) {
        if (selecedOption.length > this.selecedOption.length) {
          let selectValue = selecedOption.concat(this.selecedOption).filter(v => !selecedOption.includes(v) || !this.selecedOption.includes(v))
        }
        this.selecedOption = selecedOption;
      },
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

时间的情敌

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值