微信小程序——数组对象的增删改查 - 新闻资讯 - 云南小程序开发|云南软件开发|云南网站建设-昆明葵宇信息科技有限公司

159-8711-8523

云南网建设/小程序开发/软件开发

知识

不管是网站,软件还是小程序,都要直接或间接能为您产生价值,我们在追求其视觉表现的同时,更侧重于功能的便捷,营销的便利,运营的高效,让网站成为营销工具,让软件能切实提升企业内部管理水平和效率。优秀的程序为后期升级提供便捷的支持!

您当前位置>首页 » 新闻资讯 » 小程序相关 >

微信小程序——数组对象的增删改查

发表时间:2021-1-5

发布人:葵宇科技

浏览次数:106

微信小程序——数组对象的增、删、改、查

1.模拟数据的初始化定义

data: {
		    type_name: '项目分类',
		    name_name: '项目名称',
		    type_sId: "",
		    name_sId: "",
		    NumberValue: "", //数量
		    ExplainValue: "", //情况说明
		    RepaiSlip: [] //定义空数组
		  },

2.数据的新增

RepairInfo_add: function() {//创建新增的方法
	    var obj = {};//新增一个空对象
	    //定义对象的属性及初始化
	    obj.oid = this.data.RepaiSlip.length + 1;//定义一个oid,用于根据数组自增
	    obj.otype_sId = this.data.type_sId;//测试数据
	    obj.oname_sId = this.data.name_sId;
	    obj.otype_name = this.data.type_name;
	    obj.oname_name = this.data.name_name;
	    obj.oNumberValue = http://www.wxapp-union.com/this.data.NumberValue;
	    obj.oExplainValue = this.data.ExplainValue;
	    let RepaiSlip = this.data.RepaiSlip;
	    
	    RepaiSlip.push(obj);//将对象添加到数组对象
	
	    //给进行赋值
	    this.setData({
	      RepaiSlip,
	    })
  },

2.数据的删除

前台按钮绑定删除事件

          
          编辑
          删除
        
后台根据绑定的oid进行删除 
  // 删除按钮事件
  del_bind: function(e) {
    //取出要删除数据的oid
    var vOid = e.currentTarget.dataset.oid;
    var RepaiSlip = this.data.RepaiSlip;
    //从oid的前一个位置开始删除一位
    RepaiSlip.splice(vOid - 1, 1);
    console.log(RepaiSlip);
    this.setData({
      RepaiSlip
    })
  },

3.数据的修改
前台同上面一样,后台调用点击事件

 // 编辑按钮事件
  edit_bind: function(e) {
    var vOid = e.currentTarget.dataset.oid;//获取选择行的id
    var RepaiSlip = this.data.RepaiSlip
    const length = RepaiSlip.length
    if (vOid) {
      for (let i = 0; i <= length - 1; i++) {
        if (vOid == RepaiSlip[i].oid) {//找到后进行页面跳转
          wx.navigateTo({
            url: 'RepairInfo?JsonData='http://www.wxapp-union.com/+ JSON.stringify(RepaiSlip[i])
          })
        } else {
          console.log("没找到结果")
        }
      }
    }
  },

修改页面接收赋值

  onLoad: function(options) {
    if (options.JsonData != undefined) {
      var vData = http://www.wxapp-union.com/JSON.parse(options.JsonData)//将传过来的json字符串转换为json数组
      this.setData({//赋值
        type_sId: vData.otype_sId,
        name_sId: vData.oname_sId,
        type_name: vData.otype_name,
        name_name: vData.oname_name,
        NumberValue: vData.oNumberValue,
        ExplainValue: vData.oExplainValue
      })
    }
  },

4.数据的查询

根据数组的唯一标识循环对比查询

 var vOid = e.currentTarget.dataset.oid;//获取选择行的id
        var RepaiSlip = this.data.RepaiSlip
        const length = RepaiSlip.length
        if (vOid) {
          for (let i = 0; i <= length - 1; i++) {
            if (vOid == RepaiSlip[i].oid) {//找到后进行页面跳转
              wx.navigateTo({
                url: 'RepairInfo?JsonData='http://www.wxapp-union.com/+ JSON.stringify(RepaiSlip[i])
              })
            } else {
              console.log("没找到结果")
            }
          }
        }

相关案例查看更多