Bee.Paul 2022-12-11 03:05 采纳率: 66.7%
浏览 99
已结题

微信小程序开发,用setData()赋值变量数组失败!

问题遇到的现象和发生背景

微信小程序开发,用setData()赋值变量数组,失败!无报错 就是复制不上

遇到的现象和发生背景,请写出第一个错误信息

无报错,想要赋值的数组 数据不改变。

用代码块功能插入代码,请勿粘贴截图。 不用代码块回答率下降 50%
<view style="padding: 100rpx 0 30rpx 0;">
<text class="title">选择你要推广的平台</text>
</view>
<view class="mast">
  <view wx:for="{{menu_info}}" class="{{item.class}}" bindtap="onXzPt" data-index="{{item.id}}">
    {{item.name}}
  </view>
</view>


data: {
  menu_info:[
    {id:0,name: "抖音",class: "item",select: 1},
    {id:1,name: "快手",class: "item_f",select: 0},
    {id:2,name: "视频号",class: "item_f",select: 0},
    {id:3,name: "美团",class: "item_f",select: 0},
    {id:4,name: "小红书",class: "item_f",select: 0}
  ]
  },
  onXzPt:function (e) {
    var that = this
    let oncklik = e.currentTarget.dataset.index
    for (var i in that.data.menu_info){
      let menuid = that.data.menu_info[i].id
      var newclass = "that.data.menu_info["+i+"].class"
      if(menuid == oncklik){
        that.setData({
          [newclass] : 'item'
        })
        console.log(newclass)
        console.log(that.data.menu_info[i].class)
      }
      else{
      }
      }
  },


![img](https://img-mid.csdnimg.cn/release/static/image/mid/ask/442249896076190.png "#left")
运行结果及详细报错内容
that.data.menu_info[3].class
pt.js? [sm]:27 item_f

我的解答思路和尝试过的方法,不写自己思路的,回答率下降 60%

所有的办法都试过了,能想的能查的都用过了,还是不行,请帮助。

我想要达到的结果,如果你需要快速回答,请尝试 “付费悬赏”
  • 写回答

5条回答 默认 最新

  • 游一游走一走 2022-12-11 08:56
    关注
    Page({
      data: {
        menu_info: [{
            id: 0,
            name: "抖音",
            class: "item",
            select: 1
          },
          {
            id: 1,
            name: "快手",
            class: "item_f",
            select: 0
          },
          {
            id: 2,
            name: "视频号",
            class: "item_f",
            select: 0
          },
          {
            id: 3,
            name: "美团",
            class: "item_f",
            select: 0
          },
          {
            id: 4,
            name: "小红书",
            class: "item_f",
            select: 0
          }
        ]
      },
      onXzPt: function (e) {
        var that = this
        let oncklik = e.currentTarget.dataset.index
    
        // 获取data数据的副本
        let changeMenus = {
          ...that.data.menu_info
        }
        for (var i in changeMenus) {
          let menu = changeMenus[i]
          let menuid = menu.id
          if (menuid == oncklik) {
            menu.class = 'item'
            //将整个menu_info赋值
            that.setData({
              menu_info: changeMenus
            })
            console.log(that.data.menu_info[i].class)
            break
          } else {}
        }
      },
    })
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

问题事件

  • 系统已结题 12月19日
  • 已采纳回答 12月11日
  • 创建了问题 12月11日

悬赏问题

  • ¥50 Dkeil5 CT107D单片机的程序编写
  • ¥30 Ubuntu20.04中PVN3D复现过程交叉编译问题
  • ¥15 模拟电路求复阻抗和传递函数,请各位拍照写一下解答过程
  • ¥60 不懂得怎么运行下载来的代码
  • ¥15 CST导出3D模型图为什么和软件显示不一样?
  • ¥15 加热反应炉PLC控制系统设计(相关搜索:梯形图)
  • ¥15 python 用Dorc包报错,我的写法和网上教的是一样的但是它显示无效参数,是什么问题
  • ¥15 经过滑动平均后的一维信号还原用什么结构好呢?
  • ¥15 指定IP电脑的访问设置
  • ¥30 matlab ode45 未发现警告,但是运行出错