【微信小程序-原生开发】实用教程10 - 动态的新增、修改、删除(含微信云数据库的新增、修改、删除,表单弹窗、确认弹窗、日期选择器、单行输入框、多行输入框、滑动组件的使用)

简介: 【微信小程序-原生开发】实用教程10 - 动态的新增、修改、删除(含微信云数据库的新增、修改、删除,表单弹窗、确认弹窗、日期选择器、单行输入框、多行输入框、滑动组件的使用)

开始前,请先完成首页的动态列表和动态详情的开发,详见

【微信小程序-原生开发】实用教程 09 - 可滚动选项,动态列表-步骤条(含事件传参),动态详情(含微信云查询单条数据 doc)

https://blog.csdn.net/weixin_41192489/article/details/128811723

技术要点:操作微信云数据库

新增

      wx.cloud.database().collection('message').add({
        data: this.data.formData
      }).then

修改

      let id = this.data.currentID
      let newData = this.data.formData
      // 删除多余的表单字段
      delete newData._openid
      delete newData._id
      wx.cloud.database().collection('message').doc(id).update({
        data: newData
      }).then

删除

    let id = this.data.currentID
    wx.cloud.database().collection('message').doc(id).remove().
    then

动态的新增

悬浮按钮 t-fab

pages\index\index.json

"t-fab": "tdesign-miniprogram/fab/fab",

pages\index\index.wxml

<!-- 悬浮按钮--新增 -->
<t-fab style="right: 40rpx;bottom: 140rpx" icon="add" capture-bind:tap="add" />
  • 用 style 调整定位

pages\index\index.js

  // 新增
  add: function () {
    this.setData({
      formData: {}, // 清空表单数据
      formDialogVisible: true, // 显示表单弹窗
      formTitle: '新增' + this.data.currentLabel, // 更新表单弹窗的标题
      action: 'add' // 标记当前执行的操作是 新增 add
    })
  },

表单弹窗 t-dialog

pages\index\index.json

    "t-button": "tdesign-miniprogram/button/button",
    "t-input": "tdesign-miniprogram/input/input",
    "t-dialog": "tdesign-miniprogram/dialog/dialog",
    "t-textarea": "tdesign-miniprogram/textarea/textarea",
    "t-date-time-picker": "tdesign-miniprogram/date-time-picker/date-time-picker",

pages\index\index.wxml

<!-- 弹窗--表单 -->
<t-dialog visible="{{formDialogVisible}}" title="{{formTitle}}" confirm-btn="保存" cancel-btn="取消" bind:confirm="save" bind:cancel="closeFormDialog">

  <t-input bind:clear='inputChange' bindchange="inputChange" data-prop='title' value="{{formData.title}}" style="{{style}}" clearable slot="content" placeholder="标题" />

  <t-textarea adjust-position bindchange="inputChange" data-prop='content' value="{{formData.content}}" bordered maxcharacter="200" disableDefaultPadding="{{true}}" indicator t-class="external-class" slot="content" placeholder="内容" />

  <t-input bind:clear='inputChange' bindchange="inputChange" data-prop='publisher' value="{{formData.publisher}}" style="{{style}}" clearable slot="content" placeholder="发布人" />

  <t-input disabled capture-bind:tap="showDatePicker" data-prop='date' value="{{formData.date}}" style="{{style}}" slot="content" placeholder="日期" />
</t-dialog>

<!-- 日期选择器 -->
<t-date-time-picker data-prop='date' title="选择日期" visible="{{dateVisible}}" mode="date" defaultValue="{{today}}" value="{{formData.date}}" format="YYYY-MM-DD" bindchange="chooseDate" bindcancel="hideDatePicker" />

pages\index\index.wxss

/* 表单弹窗--多行输入框 */
.external-class {
  height: 256rpx;
  margin-top: 40rpx;
}

/* 表单弹窗--被禁用的日期输入框,强制黑色 */
.t-input__control--disabled {
  color: black !important
}

pages\index\index.js

新增 data

    // 执行的操作
    action: '',
    // 表单弹窗的标题
    formTitle: '',
    // 表单弹窗的显隐
    formDialogVisible: false,
    // 日期选择器的显隐
    dateVisible: false,
    // 日期选择器的默认值
    today: new Date().getTime(),
    // 表单数据
    formData: {},
    // 表单字段--用于表单校验
    formConfig: {
      title: "标题",
      content: "内容",
      publisher: "发布人",
      date: "日期",
    },
    // 表单输入框的样式
    style: 'border: 2rpx solid rgba(220,220,220,1);border-radius: 12rpx;margin-top:40rpx',

新增方法

  // 输入内容改变时,触发数据同步改变--实现表单数据的双向绑定
  inputChange: function (e) {
    let prop = e.currentTarget.dataset.prop
    let value = e.detail.value
    this.data.formData[prop] = value
    this.setData({
      formData: this.data.formData
    })
  },
  // 显示日期选择器
  showDatePicker() {
    this.setData({
      dateVisible: true,
    });
  },
  // 隐藏日期选择器
  hideDatePicker() {
    this.setData({
      dateVisible: false,
    });
  },
  // 选择日期
  chooseDate(e) {
    let prop = e.currentTarget.dataset.prop
    let value = e.detail.value
    this.data.formData[prop] = value
    this.setData({
      formData: this.data.formData
    })
    this.hideDatePicker();
  },
  // 表单校验
  formValid: function () {
    let result = true
    let obj = this.data.formConfig
    obj[Symbol.iterator] = function* () {
      let keys = Object.keys(obj);
      for (let k of keys) {
        yield [k, obj[k]];
      }
    };

    for (let [k, v] of obj) {
      if (!this.data.formData[k]) {
        this.warning(v)
        result = false
        break
      }
    }
    return result
  },
  // 提示--不能为空
  warning: function (label) {
    wx.showToast({
      icon: 'none',
      title: `${label}不能为空`,
    })
  },
  // 保存 (新增+修改)
  save: function () {
    if (!this.formValid()) {
      return
    }
    let action = this.data.action
    if (action === 'add') {
      wx.cloud.database().collection('message').add({
        data: this.data.formData
      }).then(
        res => {
          wx.showToast({
            title: '新增成功',
          })
          this.getinfoList()
          this.closeFormDialog()
        }
      )
    }

    if (action === 'edit') {
      let id = this.data.currentID
      let newData = this.data.formData
      // 删除多余的表单字段
      delete newData._openid
      delete newData._id
      wx.cloud.database().collection('message').doc(id).update({
        data: newData
      }).then(
        res => {
          this.actionOK()
        }
      )
    }
  },
  // 操作成功(新增/修改)
  actionOK: function () {
    let actionDic = {
      add: "新增",
      edit: "修改",
      del: "删除"
    }
    let actionLabel = actionDic[this.data.action]
    wx.showToast({
      title: `${actionLabel}成功`,
    })
    this.getinfoList()
    this.closeFormDialog()
  },
  // 隐藏表单弹窗
  closeFormDialog: function () {
    this.setData({
      formDialogVisible: false
    })
  },

动态的修改

添加修改和删除的权限

在微信云数据库中,将对应数据库的权限按下图修改

滑动组件 t-swipe-cell

pages\index\index.json

"t-swipe-cell": "tdesign-miniprogram/swipe-cell/swipe-cell"

pages\index\index.wxml

    <t-step-item wx:for="{{infoList}}" wx:key="index" title="{{item.date}}">
      <!-- 插槽 extra -- 自定义每个步骤中的内容 -->
      <t-swipe-cell slot="extra">
        <!-- 通过自定义属性 data-id 实现事件传参 -->
        <view class="contentBox" bindtap="gotoDetail" data-id="{{item._id}}">
          <view>
            {{item.title}}
          </view>
          <view>
            {{item.publisher}}
          </view>
        </view>
        <view slot="right" class="btn-wrapper">
          <view class="btn edit-btn" bind:tap="edit" data-detail="{{item}}">修改</view>
          <view class="btn delete-btn" bind:tap="del" data-id="{{item._id}}">删除</view>
        </view>
      </t-swipe-cell>
    </t-step-item>
  • 在步骤条组件的插槽中,内嵌滑动组件

pages\index\index.wxss

/* 修改、删除按钮 */
.btn-wrapper {
  height: 100%;
  padding-left: 30rpx;
}

/* 按钮通用样式 */
.btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 120rpx;
  height: 100%;
  color: white;
}

/* 删除按钮 */
.delete-btn {
  background-color: #e34d59;
}

/* 修改按钮 */
.edit-btn {
  background-color: #ed7b2f;
}

pages\index\index.js

新增 data

    // 当前操作数据的 id
    currentID: '',

新增方法

  // 修改
  edit: function (e) {
    this.setData({
      formDialogVisible: true, // 显示表单弹窗
      currentID: e.currentTarget.dataset.detail._id, // 获取操作数据的id
      formData: e.currentTarget.dataset.detail, // 将操作的数据赋值给表单
      formTitle: '修改' + this.data.currentLabel, // 更新表单弹窗标题
      action: 'edit' // 标记执行的操作为修改 edit
    })
  },

动态的删除

pages\index\index.wxml

<!-- 弹窗--删除确认 -->
<t-dialog visible="{{showDelConfirm}}" content="确定删除吗?" confirm-btn="确定" cancel-btn="取消" bind:confirm="delConfirm" bind:cancel="delCancel" />

pages\index\index.js

新增 data

    // 删除确认弹窗的显隐
    showDelConfirm: false,

新增方法

  // 删除
  del: function (e) {
    this.setData({
      currentID: e.currentTarget.dataset.id, // 获取操作数据的id
      showDelConfirm: true,  // 显示删除确认弹窗
      action: 'del' // 标记执行的操作为删除 del
    })
  },
  // 确定删除
  delConfirm: function () {
    let id = this.data.currentID
    wx.cloud.database().collection('message').doc(id).remove().
    then(
      res => {
        this.actionOK()
        this.setData({
          showDelConfirm: false
        })
      }
    )
  },
  // 取消删除
  delCancel: function () {
    this.setData({
      showDelConfirm: false
    })
  },

目录
相关文章
预约按摩小程序开发,为什么很多上门按摩平台根本招聘不到优秀技师?
上门按摩平台面临招不到优秀技师的问题,主要原因是平台众多,技师选择多样。为解决此问题,平台可引入技师等级制度,根据订单数量和好评率划分高、低等级技师。高等级技师可享受70%-90%的高提成及首页推荐,这不仅能激励技师的积极性,还能帮助平台筛选出优质技师,提升服务质量和口碑,形成良性循环。
|
1月前
|
人工智能 小程序
【一步步开发AI运动小程序】十五、AI运动识别中,如何判断人体站位的远近?
【云智AI运动识别小程序插件】提供人体、运动及姿态检测的AI能力,无需后台支持,具有快速、体验好、易集成等特点。本文介绍如何利用插件判断人体与摄像头的远近,确保人体图像在帧内的比例适中,以优化识别效果。通过`whole`检测规则,分别实现人体过近和过远的判断,并给出相应示例代码。
|
7天前
|
关系型数据库 MySQL API
新手教程:数据库操作(使用PDO或MySQLi扩展)
本文为新手介绍如何使用PDO和MySQLi扩展连接与操作MySQL数据库。PDO更现代灵活,支持多种数据库,适合大多数应用;MySQLi提供面向过程和面向对象两种API,适合直接控制数据库操作。教程涵盖安装配置、创建连接、执行查询(查询、插入、更新、删除)及错误处理等内容。希望这篇教程能帮助你快速上手PHP中的数据库操作!
57 32
|
12天前
|
开发框架 小程序 前端开发
圈子社交app前端+后端源码,uniapp社交兴趣圈子开发,框架php圈子小程序安装搭建
本文介绍了圈子社交APP的源码获取、分析与定制,PHP实现的圈子框架设计及代码编写,以及圈子小程序的安装搭建。涵盖环境配置、数据库设计、前后端开发与接口对接等内容,确保平台的安全性、性能和功能完整性。通过详细指导,帮助开发者快速搭建稳定可靠的圈子社交平台。
117 18
|
30天前
|
人工智能 小程序 UED
【一步步开发AI运动小程序】十六、AI运动识别中,如何判断人体站位?
【云智AI运动识别小程序插件】提供人体、运动及姿态检测的AI能力,本地引擎无需后台支持,具备快速、体验好、易集成等优势。本文介绍如何利用插件的`camera-view`功能,通过检测人体站位视角(前、后、左、右),确保运动时的最佳识别率和用户体验。代码示例展示了如何实现视角检查,确保用户正或背对摄像头,为后续运动检测打下基础。
|
25天前
|
人工智能 小程序 API
【一步步开发AI运动小程序】十七、如何识别用户上传视频中的人体、运动、动作、姿态?
【云智AI运动识别小程序插件】提供人体、运动、姿态检测的AI能力,支持本地原生识别,无需后台服务,具有速度快、体验好、易集成等优点。本文介绍如何使用该插件实现用户上传视频的运动识别,包括视频解码抽帧和人体识别的实现方法。
|
2月前
|
人工智能 小程序 IDE
【一步步开发AI运动小程序】九、姿态辅助调试桌面工具的使用
随着AI技术的发展,各大厂商推出的AI运动APP如“乐动力”、“天天跳绳”等,使云上运动会、线上健身等概念大热。本文将指导你如何利用“云智AI运动识别小程序插件”,在微信小程序中实现类似功能,包括工具搭建、服务启动及数据回传等步骤,助力开发者高效开发AI运动小程序。
【一步步开发AI运动小程序】九、姿态辅助调试桌面工具的使用
|
1月前
|
人工智能 小程序 API
【一步步开发AI运动小程序】十三、自定义一个运动分析器,实现计时计数02
本文介绍如何利用“云智AI运动识别小程序插件”开发AI运动小程序,详细解析了俯卧撑动作的检测规则构建与执行流程,涵盖卧撑和撑卧两个姿态的识别规则,以及如何通过继承`sports.SportBase`类实现运动分析器,适用于小程序开发者。
|
1月前
|
人工智能 小程序 API
【一步步开发AI运动小程序】十二、自定义一个运动分析器,实现计时计数01
随着AI技术的发展,AI运动APP如雨后春笋般涌现,如“乐动力”、“天天跳绳”等,推动了云上运动会、线上健身等热潮。本文将指导你从零开始开发一个AI运动小程序,利用“云智AI运动识别小程序插件”,介绍运动识别原理、计量方式及运动分析器基类的使用,帮助你在小程序中实现运动计时和计数功能。下篇将继续探讨运动姿态检测规则的编写。
|
2月前
|
人工智能 JSON 小程序
【一步步开发AI运动小程序】八、利用body-calc进行姿态识别
随着AI技术的发展,各大厂商推出的如“乐动力”、“天天跳绳”等AI运动APP,使得云上运动会、线上健身等概念风靡一时。本文将引导读者从零开始开发一个AI运动小程序,使用“云智AI运动识别小程序插件”,介绍人体姿态检测规则、规则编写语法、执行检测规则运算及姿态检测实战等内容,助力开发者轻松实现AI运动小程序的开发。
【一步步开发AI运动小程序】八、利用body-calc进行姿态识别