【轻松开发微信小程序】实现用户增删改查功能

简介: 本篇文章主要介绍如何从零开始开发微信小程序,并以实现用户增删改查功能为例,详细讲解了小程序的目录结构、项目创建、编码等方面。通过本文的学习,读者可以了解到微信小程序开发的基本流程和常见操作,为深入学习和实践提供了基础。

前言

上一篇博客中我们学习了什么是小程序以及开发一个小程序的具体步骤。

在本篇博客中,我们来开发一个用户列表增删改查功能的完整流程,包括微信小程序项目目录、项目创建、编码、实现功能以及最终效果的展示。

image.png

创建微信小程序项目

首先,在微信开发者工具中,选择新建小程序项目,填写小程序名称、AppID以及项目路径,点击确定即可创建微信小程序项目。

创建项目目录结构

在创建好的微信小程序项目中,创建以下目录结构:

- pages/
  - index/
    - index.js
    - index.json
    - index.wxml
    - index.wxss
  - edit/
    - edit.js
    - edit.json
    - edit.wxml
    - edit.wxss
- app.js
- app.json
- app.wxss

编写首页页面

在pages目录下,创建一个index目录,用于存放首页页面相关文件。在index目录下,创建以下文件:

- index.js
- index.json
- index.wxml
- index.wxss

在index.js中,编写以下代码:

// index.js
Page({
   
  data: {
   
    listData: []
  },
  onLoad: function () {
   
    // 页面加载时,从本地缓存中获取数据
    const listData = wx.getStorageSync('listData') || []
    this.setData({
   
      listData
    })
  },
  gotoAdd: function () {
   
    // 跳转到添加页面
    wx.navigateTo({
   
      url: '/pages/edit/edit',
    })
  },
  gotoEdit: function (e) {
   
    // 跳转到编辑页面
    const id = e.currentTarget.dataset.id
    wx.navigateTo({
   
      url: `/pages/edit/edit?id=${
     id}`,
    })
  },
  deleteData: function (e) {
   
    // 删除数据
    const id = e.currentTarget.dataset.id
    const listData = wx.getStorageSync('listData') || []
    const index = listData.findIndex(item => item.id === Number(id))
    listData.splice(index, 1)
    wx.setStorageSync('listData', listData)
    this.setData({
   
      listData
    })
  }
})

在index.wxml中,编写以下代码:

<!-- index.wxml -->
<view class="container">
  <button class="add-btn" bindtap="gotoAdd">添加</button>
  <view class="list">
    <block wx:for="{
    {listData}}" wx:key="id">
      <view class="item" bindtap="gotoEdit" data-id="{
    {item.id}}">
        <text class="text">{
  {item.text}}</text>
        <text class="delete" bindtap="deleteData" data-id="{
    {item.id}}">删除</text>
      </view>
    </block>
  </view>
</view>

在index.wxss中,编写以下代码:

/* index.wxss */
.container {
   
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 20rpx;
}

.add-btn {
   
  width: 80%;
  background-color: #4caf50;
  color: #fff;
  border-radius: 5rpx;
  padding: 10rpx;
  text-align: center;
  margin-bottom: 20rpx;
}

.list {
   
  width: 80%;
}

.item {
   
  display:flex;
  justify-content: space-between;
  align-items: center;
  padding: 10rpx;
  background-color: #fff;
  border-radius: 5rpx;
  margin-bottom: 10rpx;
  box-shadow: 0 0 10rpx rgba(0, 0, 0, 0.2);
}

.text {
   
  font-size: 16rpx;
}

.delete {
   
color: red;
font-size: 14rpx;
}

在index.json中,编写以下代码:

{
   
  "navigationBarTitleText": "首页"
}

编写编辑页面

在pages目录下,创建一个edit目录,用于存放编辑页面相关文件。在edit目录下,创建以下文件:

- edit.js
- edit.json
- edit.wxml
- edit.wxss

在edit.js中,编写以下代码:

// edit.js
Page({
   
  data: {
   
    id: 0,
    text: ''
  },
  onLoad: function (options) {
   
    if (options.id) {
   
      // 如果是编辑页面,从本地缓存中获取数据
      const listData = wx.getStorageSync('listData') || []
      const data = listData.find(item => item.id === Number(options.id))
      this.setData({
   
        id: data.id,
        text: data.text
      })
    }
  },
  handleInput: function (e) {
   
    // 监听输入框输入事件
    this.setData({
   
      text: e.detail.value
    })
  },
  handleSave: function () {
   
    // 保存数据
    const listData = wx.getStorageSync('listData') || []
    let {
    id, text } = this.data
    if (id) {
   
      // 如果是编辑数据,修改原有数据
      const index = listData.findIndex(item => item.id === Number(id))
      listData[index] = {
   
        id: Number(id),
        text
      }
    } else {
   
      // 如果是新增数据,生成新的id,并添加到列表中
      id = listData.length ? listData[listData.length - 1].id + 1 : 1
      listData.push({
   
        id,
        text
      })
    }
    wx.setStorageSync('listData', listData)
    wx.navigateBack()
  }
})

在edit.wxml中,编写以下代码:

<!-- edit.wxml -->
<view class="container">
  <input class="input" type="text" placeholder="请输入内容" value="{
    {text}}" bindinput="handleInput" />
  <button class="save-btn" bindtap="handleSave">保存</button>
</view>

在edit.wxss中,编写以下代码:

/* edit.wxss */
.container {
   
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 20rpx;
}

.input {
   
  width: 80%;
  height: 80rpx;
  font-size: 16rpx;
  border-radius: 5rpx;
  padding: 20rpx;
  background-color: #fff;
  box-shadow: 0 0 10rpx rgba(0, 0, 0, 0.2);
  margin-bottom: 20rpx;
}

.save-btn {
   
  width: 80%;
  background-color: #4caf50;
  color: #fff;
  border-radius: 5rpx;
  padding: 10rpx
}

实现增删改查功能

在index.js中,添加以下代码:

// index.js
Page({
   
  data: {
   
    listData: []
  },
  onShow: function () {
   
    // 页面显示时,从本地缓存中获取数据,并更新数据
    const listData = wx.getStorageSync('listData') || []
    this.setData({
   
      listData
    })
  },
  handleAdd: function () {
   
    // 点击新增按钮,跳转到编辑页面
    wx.navigateTo({
   
      url: '/pages/edit/edit'
    })
  },
  handleEdit: function (e) {
   
    // 点击列表项,跳转到编辑页面,并携带id参数
    const id = e.currentTarget.dataset.id
    wx.navigateTo({
   
      url: `/pages/edit/edit?id=${
     id}`
    })
  },
  handleDelete: function (e) {
   
    // 点击删除按钮,删除该项数据,并更新本地缓存
    const id = e.currentTarget.dataset.id
    const listData = wx.getStorageSync('listData') || []
    const index = listData.findIndex(item => item.id === Number(id))
    listData.splice(index, 1)
    wx.setStorageSync('listData', listData)
    this.setData({
   
      listData
    })
  }
})

在index.wxml中,修改以下代码:

<!-- index.wxml -->
<view class="container">
  <button class="add-btn" bindtap="handleAdd">新增</button>
  <view class="list">
    <block wx:for="{
    {listData}}" wx:key="id">
      <view class="list-item" bindtap="handleEdit" data-id="{
    {item.id}}">
        <text class="text">{
  {item.text}}</text>
        <text class="delete" bindtap="handleDelete" data-id="{
    {item.id}}">删除</text>
      </view>
    </block>
  </view>
</view>

至此,一个简单的小程序用户列表增删改查功能就完成了。

展示最终效果

使用微信开发者工具打开项目,点击编译运行按钮,即可看到最终效果。

总结

本文介绍了开发微信小程序所需的基本知识,包括微信小程序的目录结构、项目创建、编码等方面。并以一个简单的用户列表增删改查功能为例,演示了如何在小程序中实现常见的增删改查操作。

需要注意的是,本文只是一个入门级别的示例,实际的小程序开发中可能会涉及更多的技术和知识,例如网络请求、数据绑定、组件开发等等。如果想要深入了解微信小程序开发,建议多阅读官方文档和相关书籍,积累更多的实战经验。

希望本文对初学者有所帮助,如果有任何问题或建议,欢迎留言讨论。


✍创作不易,求关注😄,点赞👍,收藏⭐️

相关文章
|
7月前
|
人工智能 小程序 前端开发
一个小程序轻量AR体感游戏,开发实现解决方案
针对青少年运动兴趣不足问题,AR体感游戏凭借沉浸式互动体验脱颖而出。结合小程序“AI运动识别”插件与WebGL渲染技术,可实现无需外设的轻量化AR健身游戏,如跳糕、切水果等,兼具趣味性与锻炼效果,适用于儿童健身及职工团建,即开即玩,低门槛高参与。
|
7月前
|
运维 小程序 数据可视化
小程序开发平台有哪些?SaaS小程序制作平台哪个好
小程序开发模式详解:自主开发、SaaS小程序制作平台与外包全对比 选择合适的小程序开发模式,是项目成功的基石。这三种模式在成本、周期、控制力和灵活性上各有千秋,适用于不同阶段和不同类型的企业。下面我们将逐一深入剖析。
594 9
|
7月前
|
移动开发 小程序 前端开发
小程序开发平台有哪些?哪个好
小程序的开发方式丰富多元,开发团队可根据自身的技术背景、项目具体需求以及资源状况,灵活挑选最为适宜的开发路径。以下将详细介绍几种主流的小程序开发方式。
631 2
|
7月前
|
移动开发 小程序 前端开发
小程序快速开发平台有哪些?
小程序开发并非“一刀切”,需结合技术储备、资金预算、时间规划及功能需求等多维度因素综合考量。以下为您详细拆解五种主流开发方案及其适用场景,助您精准匹配开发路径。
420 3
|
8月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。
|
7月前
|
移动开发 小程序 前端开发
小程序开发平台有哪些?小程序开发制作软件推荐
小程序开发方案全解析:5种主流方式与选择指南 小程序开发需根据技术能力、预算、时间及功能需求综合决策。以下为5种主流开发方案及适用场景分析:
26255 0
|
9月前
|
小程序 JavaScript API
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
这篇文章介绍了使用uni-halo框架进行微信小程序开发的过程,包括选择该框架的原因、开发目标以及项目配置和部署的步骤。
480 0
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
|
自然语言处理 搜索推荐 小程序
微信公众号接口:解锁公众号开发的无限可能
微信公众号接口是微信官方提供的API,支持开发者通过编程与公众号交互,实现自动回复、消息管理、用户管理和数据分析等功能。本文深入探讨接口的定义、类型、优势及应用场景,如智能客服、内容分发、电商闭环等,并介绍开发流程和工具,帮助运营者提升用户体验和效率。未来,随着微信生态的发展,公众号接口将带来更多机遇,如小程序融合、AI应用等。