微信小程序管理奖品(抽奖)

话不多说直接上代码

功能:

使用微信小程序vant-weapp 组件库中的upload组件以及两个input框

最后拿到的值是一个数组对象的形式

主要代码如下:

wxml

html 复制代码
<view wx:for="{{prizes}}" wx:key="index" class="inputs">
            <input style="width:31%;border-radius:10rpx" value="{{item.name}}" placeholder="奖品名称" bindinput="handleInput" data-type="name" data-index="{{index}}" />
            <input style="width:31%;border-radius:10rpx" value="{{item.gl}}" placeholder="奖品概率" bindinput="handleInput" data-type="gl" data-index="{{index}}" />
            <van-uploader file-list="{{ item.fileList }}" max-count="1" bind:after-read="afterRead" deletable="{{ true }}" bind:delete="deleteImage" data-index="{{index}}" />
        </view>

js

javascript 复制代码
data: {
    prizes: Array.from({ length: 8 }, () => ({
      name: "",
      gl: "",
      img: "",//存储图片路径
      fileList: [],//上传图片所用
    })),
  },
//input所绑定的事件
 handleInput(e) {
    const { index, type } = e.currentTarget.dataset;
    const { value } = e.detail;
    const prizes = this.data.prizes;
    prizes[index][type] = value;
    this.setData({ prizes });
  },
   //上传
  afterRead(event) {
    const { file } = event.detail;
    const { index } = event.currentTarget.dataset; 
    console.log(file, "file");
    wx.uploadFile({
      url: "自己的路径",
      filePath: file.url, 
      name: "file",
      formData: { user: "test" },
      header: {
        //自己的请求头,
      },
      success: (res) => {
        let { data } = JSON.parse(res.data);
        console.log(data, "data");
        const prizes = this.data.prizes;
        prizes[index].img = data.url;
        prizes[index].fileList.push({ url: file.url, dataUrl: file.url });
        this.setData({ prizes });
      },
      fail: (e) => {
        console.log(e, "fail");
      },
    });
  },
  //删除图片
  deleteImage(event) {
    const { index } = event.currentTarget.dataset;
    const prizes = this.data.prizes.slice();
    prizes[index].fileList = [];
    prizes[index].img = "";
    this.setData({ prizes });
  },

需要赋值回显的话:

javascript 复制代码
onLoad(options) {
    let fileList = []; // 初始化 fileList 变量为空数组
    const prizes = [
      { name: "奖品1", gl: "概率1", img: "/uploads/20231221/4a4595fbd2b102b0eea8982133b64cfc.png"},
      { name: "奖品2", gl: "概率2", img: "/uploads/20231221/4a4595fbd2b102b0eea8982133b64cfc.png"},
      { name: "奖品3", gl: "概率3", img: "/uploads/20231221/4a4595fbd2b102b0eea8982133b64cfc.png"},
      { name: "奖品4", gl: "概率4", img: "/uploads/20231221/4a4595fbd2b102b0eea8982133b64cfc.png"},
      { name: "奖品5", gl: "概率5", img: "/uploads/20231221/4a4595fbd2b102b0eea8982133b64cfc.png"},
      { name: "奖品6", gl: "概率6", img: "/uploads/20231221/4a4595fbd2b102b0eea8982133b64cfc.png"},
      { name: "奖品7", gl: "概率7", img: "/uploads/20231221/4a4595fbd2b102b0eea8982133b64cfc.png"},
      { name: "奖品8", gl: "概率8", img: "/uploads/20231221/4a4595fbd2b102b0eea8982133b64cfc.png"},
    ];
    const prizesWithFileList = prizes.map(prize => ({
      ...prize,
      fileList: [ ...fileList, { url: prize.img } ]
    }));
    this.setData({ prizes:prizesWithFileList });
    console.log(this.data.prizes,'赋值回显');
  },

确认提交按钮

javascript 复制代码
 handleButtonClick() {
  const { prizes } = this.data;
  //这里是把数组中的每一个对象的fileList去掉
  let arr = prizes.map(({ fileList, ...rest }) => rest);
  console.log(arr, "最终数据");
  const hasEmptyField = prizes.some((prize) => {
    return prize.name === "" || prize.gl === "" || prize.img === "";
  });
  if (hasEmptyField) {
    wx.showToast({
      title: "请填写完整后提交",
      icon: "none",
    });
  } else {
    // 执行提交事件,请求接口
  }
},

记得点赞关注,后续会发布更多实用文章

相关推荐
小小王app小程序开发10 小时前
盲盒小程序一番赏衍生玩法:魔王赏、非酋赏、狂欢赏差异化分析
小程序
2501_9151063212 小时前
iOS App 测试工具全景分析,构建从开发调试到线上监控的多阶段工具链体系
android·测试工具·ios·小程序·uni-app·iphone·webview
头发还在的女程序员1 天前
基于JAVA语言的短剧小程序-抖音短剧小程序
java·开发语言·小程序
2501_916007471 天前
iOS 应用性能测试的工程化流程,构建从指标采集到问题归因的多工具协同测试体系
android·ios·小程序·https·uni-app·iphone·webview
源码_V_saaskw1 天前
JAVA国际版同城跑腿源码快递代取帮买帮送同城服务源码支持Android+IOS+H5
android·java·ios·微信小程序
tbit2 天前
fluwx 拉起小程序WXLog:Error:fail to load Keychain status:-25300, keyData null:1
flutter·ios·微信小程序
book多得2 天前
刷题专用微信小程序推荐
微信小程序·小程序
00后程序员张2 天前
iOS 抓不到包怎么办?从 HTTPS 解密、QUIC 排查到 TCP 数据流分析的完整解决方案
android·tcp/ip·ios·小程序·https·uni-app·iphone
技术与健康2 天前
微信小程序云开发实践:共享环境与LLM整合经验
微信小程序·小程序
老华带你飞2 天前
社区养老保障|智慧养老|基于springboot+小程序社区养老保障系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·小程序·毕设·社区养老保障