当前位置: 首页 > news >正文

微信小程序实战-01翻页时钟-1

文章目录

  • 前言
  • 需求分析
  • 功能设计
    • 界面设计
      • 界面结构设计
      • 界面样式设计
    • 逻辑设计
  • 单页功能实现
  • 运行结果

前言

我经常在手机上用的一款app有一个功能是翻页时钟,基于之前学习的小程序相关的基础内容,我打算在微信小程序中也设计一个翻页时钟功能,Just do it!

需求分析

作为练手项目,需求比较简单,两个功能:

  1. 支持时、分、秒显示;
  2. 支持翻页效果;

整体效果大概是这个样子:

请添加图片描述

功能设计

界面设计

界面结构设计

wxml整体结构比较简单,设计6个页面和两组“:”。

界面样式设计

wxss的样式(CSS)对于我来说还是很陌生,没做过前端,也是边学边干。总体涉及的CSS的知识点会比较杂,对于样式的描述如果是动态的部分,还是不太了解,用文字描述也会不太容易。涉及的知识点,通过代码注释和理论结合进行阐述。

整体的样式也如上图所示。

逻辑设计

主要是通过js来完成计时和翻页的功能。

首先,我会先完成一个页面的渲染;然后再完成6个页面的渲染和计时,最后再完成动态翻页效果。

单页功能实现

本文先记录一个时钟数字页的渲染实现过程。

因为要有“翻页”,所以一个页面由一个view组件(item)来构造,由于涉及翻页,所以每个item设计成上下半部和一个页轴。上下半部也是通过view组件来构造,页轴通过样式来构造。

clock.wxml代码如下:

<!-- clock.wxml -->
<view class="container"><view class="item"><view class="up"><view class="number">5</view></view><view class="down"><view class="number">5</view></view></view>
</view>

clock.wxss代码如下:

/* 设置item的样式,固定宽高 */
.item {position: relative;width: 90rpx;height: 155rpx;border:1rpx solid rgba(121, 121, 121, 0.384);box-shadow: 0 2rpx 18rpx rgba(0,0,0,0.7);border-radius: 10rpx;
}/* 时钟的单个数字 */
.number{position: absolute;/* border: 1px solid red; 调试用 */width: 100%;height: 155rpx;color: #252525;text-align: center;text-shadow: 0 2rpx 4rpx rgb(0, 0, 0);font-size: 118rpx;font-weight: bold;
}/* 页轴 */
.item::before{position: absolute;content: '';top: 75rpx;width: 100%;height: 5rpx;background-color: rgba(0, 0, 0, 0.5);
}/*  掩盖“down”的上半部分 */
.down{position: absolute;width: 100%;height: 50%;overflow: hidden;bottom: 0;
}
.down .number{bottom: 0;
}/* 掩盖“up”的下半部分 */
.up{position: absolute;width: 100%;height: 50%;overflow: hidden;
}

上述的CSS样式代码都是结合调试工具,一点点调试出来的。在这个过程中,会慢慢地去了解不同的属性的作用和使用、不同选择器的使用、不同布局、怎样将元素定位。

对初学者来说,我当前的体会是通过开发者工具的调试器去查看详细的元素信息,同时,不断的去尝试,直到get你想要的渲染效果。中间会有很多尝试都是不奏效,从结果的角度来说可能是无用功,但是从学习的角度来说对CSS的知识点又增进了一些。因为CSS的知识点比较碎,比较多,有些概念也是初次遇到,所以这部分的调试工作会花费比较多的时间。不知道有没有更高效的工具或手段来完成CSS部分的工作,我目前所用的方式估计是最原始的手段,step by step。但是,当调试出自己想要的效果且知道每行代码的作用以及背后的知识点时,还是比较满意的。

运行结果

请添加图片描述

http://www.lryc.cn/news/276074.html

相关文章:

  • BigDecimal的性能问题
  • Defi安全-Monox攻击事件Foundry复现
  • 大二上总结和寒假计划
  • 使用 pdfh5 实现 pdf 预览功能
  • HttpRunner辅助函数debugtalk.py
  • PC端扫描小程序二维码登录
  • 计算机毕业设计 | SpringBoot+vue移动端音乐网站 音乐播放器(附源码)
  • Flutter 中的 Stream:异步编程的利器
  • 2023 波卡年度报告选读:Polkadot SDK 与开发者社区
  • 深入了解Go语言中的unsafe.Sizeof():探究变量与数据类型的内存占用
  • 安卓上使用免费的地图OpenStreetMap
  • 基于Java SSM框架实现时间管理系统项目【项目源码+论文说明】
  • Mac安装upx及不同os计算md5值
  • Qt/C++编写视频监控系统82-自定义音柱显示
  • SpringBoot 如何 配置端口号
  • 跟随chatgpt从零开始安装git(Windows系统)
  • C++类与对象基础(6)
  • OS_lab——分页机制与内存管理
  • 【面试】Redis基础知识
  • CentOS 9 (stream) 安装 Docker
  • vite中配置服务代理
  • kotlin 中 any, all , none
  • 如何使用 Python、Node.js 和 Go 创建基于 YOLOv8 的对象检测 Web 服务
  • pod节点jar包替换流程
  • Pytorch:torch.nn.Module
  • 传统图像处理学习笔记更新中
  • Hyperledger Fabric Java App Demo
  • Doris 在工商信息商业查询平台的湖仓一体建设实践(02)
  • 218.【2023年华为OD机试真题(C卷)】攀登者2(动态规划-JavaPythonC++JS实现)
  • 【精通C语言】:分支结构switch语句的灵活运用