百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

开发微信记账本小程序之技术要点记录

bigegpt 2024-10-12 06:27 3 浏览

我喜欢极简风格,所以我搭建了这款微信记账本小程序。在开发微信记账本小程序过程中,有一些值得关注的技术要点,我则简而记之。

1、空态界面

在没有数据时,我设计了空状态时的占位提示。

在框架中,我使用了 wx:if="{{ isShow }}" 来判断是否需要渲染该代码块。而isShow的赋值逻辑是通过判断数组的长度,如果为0则为false,否则为true。

2、新增记账

这里我基于表单元素封装了一个业务表单组件,通过遮罩层弹出。使用到的表单项有form、input、radio、textarea、picker、button,通过自定义样式实现定制化界面。

其实,我有考虑过使用Skyline进行渲染的。但是由于还不太掌握,所以还是使用自定义组件的方式,实现弹层效果。

况且,这个模块后面还会在其他地方用到,所以为了提高可复用性才做了封装。


那么,在微信小程序中,如何封装自定义组件和引用呢?

1) 创建自定义组件:

首先,在项目根目录下创建一个文件夹 `components`,用于存放自定义组件。

在 `components` 文件夹下创建一个子文件夹`my-component`,用于存放自定义组件的相关文件。

在 `my-component` 文件夹下创建以下四个文件:

  • `my-component.wxml`:组件的模板结构。
  • `my-component.wxss`:组件的样式表。
  • `my-component.js`:组件的逻辑代码。
  • `my-component.json`:组件的配置信息。

编写组件的代码,然后在需要使用该组件的页面中进行引用。

2)引用自定义组件:

在需要使用自定义组件的页面的 `json` 文件中,添加 `usingComponents` 字段,用于声明要使用的自定义组件。

     // json
     {
       "usingComponents": {
         "my-component": "/components/my-component/my-component"
       }
     }
     

在页面的 `wxml` 文件中,使用自定义组件的标签来引用它。

     // wxml
     <my-component></my-component>

注意,自定义组件的名称必须遵循一定的命名规范,即以字母开头,可以包含数字、下划线、横杠等字符。

这样,就大致上在微信小程序中使用自定义组件了。接下来,就是写页面结构布局与样式,还有业务逻辑代码了。

这里的拖拽效果,我是基于框架提供的draggable-sheet 组件实现的,封装了这一能力,包括:

  • 隐藏滚动条
  • 滚动回弹效果
  • 滚动到指定位置(snap 到关键点)
  • 滚动帧回调(实现滚动驱动动画)
<draggable-sheet
  class="sheet"
  initial-child-size="0.5"
  min-child-size="0.2"
  max-child-size="0.8"
  snap="{{true}}"
  snap-sizes="{{[0.4, 0.6]}}"
  worklet:onsizeupdate="onSizeUpdate"
>
  <scroll-view
    scroll-y="{{true}}"
    type="list"
    associative-container="draggable-sheet"
    bounces="{{true}}"
  />
</draggable-sheet>

3、选择类型和分类管理

这里的长按拖动分类排序,我认为也是一个技术难点。

实现长按拖拽某个选项进行排序,我采用了以下技术方案来实现。

首先,在页面的 `wxml` 文件中,为每个选项添加一个 `touchstart` 和 `touchmove` 事件监听器。

// wxml
<view class="item" bindtouchstart="startDrag" bindtouchmove="drag" data-index="{{index}}">
  {{item}}
</view>

在对应的 `js` 文件中,定义 `startDrag` 和 `drag` 方法。`startDrag` 方法用于记录触摸开始时的位置和索引,`drag` 方法用于处理拖拽过程中的逻辑。

// javascript
Page({
  data: {
    items: ['餐饮', '交通', '服饰']
  },
  startDrag: function (e) {
    // 记录触摸开始时的位置和索引
    this.setData({
      startX: e.touches[0].clientX,
      startY: e.touches[0].clientY,
      startIndex: e.currentTarget.dataset.index
    });
  },
  drag: function (e) {
    // 获取触摸移动时的位置
    const moveX = e.touches[0].clientX;
    const moveY = e.touches[0].clientY;
    const startX = this.data.startX;
    const startY = this.data.startY;
    const startIndex = this.data.startIndex;




    // 计算拖拽的距离
    const distanceX = moveX - startX;
    const distanceY = moveY - startY;




    // 如果拖拽距离大于一定阈值,则认为是拖拽操作
    if (Math.abs(distanceX) > 10 || Math.abs(distanceY) > 10) {
      // 获取当前拖拽的元素
      const currentItem = this.data.items[startIndex];
      // 从数组中移除当前元素
      const newItems = this.data.items.filter((item, index) => index !== startIndex);
      // 计算新的插入位置
      const newIndex = startIndex + Math.round(distanceX / 100);
      // 将当前元素插入到新的位置
      newItems.splice(newIndex, 0, currentItem);
      // 更新数据
      this.setData({
        items: newItems
      });
    }
  }
});

这样,当用户长按并拖动某个选项时,选项会根据拖动的距离进行重新排序。

4、智能分类和报表分析

为了实现日、月的收支报表,以及分类统计图表,我采用了echarts可视化图表库。这也是一项大工程,后面再单独展开写一下。

5、账目管理

看,这里修改数据的模块,就是引用了前面封装的组件。这开发效率,杠杠滴。

而删除前询问用户以避免误删数据,我是使用了框架的wx.showModal方法显示模态对话框。

当然,还有更多开发过程中的技术要点和开发技巧。但是如果都要一一细写,恐怕就要等后面出教程了。

相关推荐

Redis集群对比:主从复制、哨兵模式、Cluster一文看懂所有优缺点

在分布式系统中,Redis作为高性能的内存数据库,其集群方案的选择直接影响到系统的稳定性、可用性和扩展性。本文将全面对比Redis的三种主流集群方案:主从复制、哨兵模式和Cluster模式,帮助开发者...

redis的主从复制,读写分离,主从切换

当数据量变得庞大的时候,读写分离还是很有必要的。同时避免一个redis服务宕机,导致应用宕机的情况,我们启用sentinel(哨兵)服务,实现主从切换的功能。redis提供了一个master,多个sl...

# Redis 入门到精通(九)-- 主从复制(3)

#Redis入门到精通(九)--主从复制(3)##一、redis主从复制-常见问题(1)###1、伴随着redis系统的运行,master的数据量会越来越大,一旦master重启...

redis - 主从复制(Redis主从复制时序图)

1引言在上一篇文章中,我们了解了Redis两种不同的持久化方式,Redis服务器通过持久化,把Redis内存中持久化到硬盘当中,当Redis宕机时,我们重启Redis服务器时,可以由RDB文件或AO...

# Redis 入门到精通(九)-- 主从复制(2)

#Redis入门到精通(九)--主从复制(2)##一、redis主从复制--数据同步阶段注意事项###1、数据同步阶段master说明1)如果master数据量巨大,数据同步阶段应...

Redis主从复制(redis主从复制主节点挂了)

介绍Redis有两种不同的持久化方式,Redis服务器通过持久化,把Redis内存中持久化到硬盘当中,当Redis宕机时,我们重启Redis服务器时,可以由RDB文件或AOF文件恢复内存中的数据。不过...

深入解析 Redis 集群的主从复制实现方式

在互联网大厂的后端开发领域,Redis作为一款高性能的内存数据库,被广泛应用于缓存、消息队列等场景。而Redis集群中的主从复制机制,更是保障数据安全、实现读写分离以及提升系统性能的关键所在。今...

Redis主从架构详解(redis主从架构高可用如何实现)

Redis主从架构搭建Redis主节点配置创建主节点目录(/opt/redis-master),复制redis.conf到该目录下,redis.conf配置项修改#后台启动daemonizeyes...

抖音“四大包塘战神”:承包了全网的快乐

在抖音钓鱼垂类领域,"包塘战神"军团正掀起一场黑色幽默风暴。空军华、大表坑、李赔光、透心良四位创作者,以承包鱼塘为舞台,用连续翻车的钓鱼直播构筑起流量奇观。当钓鱼佬在抖音集体转型喜剧人...

ORACLE 11G RAC 安装-通过VM配置共享磁盘

简介:在自己的电脑上通过VM软件搭建Oracle11GRAC,通过修改VM的参数文件来实现磁盘共享!目标:搭建RAC环境实现:使用VMwareWorkstation8.0.0+ORACLE...

Linux操作系统安全配置(linux系统安全配置包括)

一、服务相关命令systemctlenable服务名#开机自启动systemctldisable服务名#禁用开机自启动systemctlstop服务名#停止服务systemctls...

关于Linux性能调优中网络I/O的一些笔记

写在前面和小伙伴分享一些Linux网络优化的笔记,内容很浅,可以用作入门博文内容结合《Linux性能优化》读书笔记整理涉及内容包括常用的优化工具(mii-tool,ethtool,ifconfig,i...

从 Sonatype Nexus Repository Manager 迁移到 Artifactory

1.Nexus1.1下载下载链接:https://help.sonatype.com/repomanager3/product-information/download/download-archiv...

Ubuntu20安装zabbix5.0企业监控系统亲测教程

前言示例主机:zabbix10.0.100.10,将安装在UbuntuServer上教程说明:因使用官方教程无法安装成功,所以本教程与官方教程有所不同安装前提:已安装UbuntuServer2...

Linux内核设计与实现—进程管理(linux内核程序设计)

进程进程就是处于执行期的程序(目标码存放在某种存储介质上)。进并不仅仅局限于一段可执行程序代码(Unix称其为代码段,textsection)。通常进程还要包含其他资源,像打开的文件,挂起的信号,...