轻源码

  • QingYuanMa.com
  • 全球最大的互联网技术和资源下载平台
搜索
一起源码网 门户 微信小程序 查看主题

微信小程序入门之构建一个简单TODOS应用

发布者: flashalone | 发布时间: 2018-7-16 19:53| 查看数: 5791| 评论数: 1|帖子模式

作者:Eraser's,来自授权地址 
最近,由于工作需要开始了解微信小程序,虽然小程序已经出了很久了,刚出的那段时间很火,看到很多关于小程序的技术文章,不过现在似乎没那么火了,anyway,我们还是可以学习下的。

一、了解微信小程序

1.理念:小程序开发框架的目标是通过尽可能简单、高效的方式让开发者可以在微信中开发具有原生 APP 体验的服务。 
2.框架:框架的核心是一个响应的数据绑定系统。整个系统分为两块视图层(View)和逻辑层(App Service),框架可以让数据与视图非常简单地保持同步。当做数据修改的时候,只需要在逻辑层修改数据,视图层就会做相应的更新。 
3.相关资料:调试工具下载,简易教程 
初步了解这些基本信息后,我们先来看下TODOS这个应用做出来的最终效果

二、TODOS应用功能演示及目录结构

功能演示: 

目录结构: 

主要功能模块为:

index页面,新建任务,可完成增删等操作 
los页面,记录在index页面的操作

下面我们详细介绍下

三、代码详解

1.简单配置app.json文件:

  1. {
  2. "pages":[
  3. "pages/index/index", // 设置页面路径,项目打开后找到这个路径下的文件
  4. "pages/logs/logs"
  5. ],
  6. "window":{ // 设置默认页面的窗口表现
  7. "backgroundTextStyle":"light",
  8. "navigationBarBackgroundColor": "#fff",
  9. "navigationBarTitleText": "TODOS",
  10. "navigationBarTextStyle":"black"
  11. },
  12. "tabBar": { // 设置底部tab的表现
  13. "borderStyle": "white",
  14. "backgroundColor": "#f5f5f5",
  15. "selectedColor": "#222",
  16. "list": [ // 对应底部下面两个菜单项;TODOS和LOGS
  17. {
  18. "pagePath": "pages/index/index",
  19. "text": "TODOS",
  20. "iconPath": "images/home.png",
  21. "selectedIconPath": "images/home-actived.png"
  22. },
  23. {
  24. "pagePath": "pages/logs/logs",
  25. "text": "LOGS",
  26. "iconPath": "images/note.png",
  27. "selectedIconPath": "images/note-actived.png"
  28. }
  29. ]
  30. }
  31. }

2.app.js和app.wxss文件

App() 函数用来注册一个小程序。接受一个 object 参数,其指定小程序的生命周期函数等。App() 必须在 app.js 中注册,且不能注册多个。 
示例代码

  1. App({
  2. onLaunch: function() {
  3. // Do something initial when launch.
  4. },
  5. onShow: function() {
  6. // Do something when show.
  7. },
  8. onHide: function() {
  9. // Do something when hide.
  10. },
  11. onError: function(msg) {
  12. console.log(msg)
  13. },
  14. globalData: 'I am global data'
  15. })

在这个项目中不需要加什么代码在App({})中,所以文件中只有一个App({}) 
app.wxss文件主要可以设置一些全局样式

  1. page {
  2. height: 100%;
  3. font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  4. }

3.注册页面Page

Page() 函数用来注册一个页面。接受一个 object 参数,其指定页面的初始数据、生命周期函数、事件处理函数等。

一.初始化数据

  1. // ===== 页面数据对象 =====
  2. data: {
  3. input: '',
  4. todos: [],
  5. leftCount: 0,
  6. allCompleted: false,
  7. logs: [],
  8. addOneLoading: false,
  9. loadingHidden: true,
  10. loadingText: '',
  11. toastHidden: true,
  12. toastText: '',
  13. clearAllLoading: false
  14. },

初始化数据作为页面的第一次渲染。data将会以JSON的形式由逻辑层传至渲染层,其数据可以是:字符串,数字,布尔值,对象,数组。 
渲染层可以通过WXML对数据进行绑定。

  1. <input class="new-todo" value="{{ input }}" placeholder="Anything here..." auto-focus bindinput="inputChangeHandle" bindchange="addTodoHandle"/>

如上述代码中的input.

二.生命周期函数

  1. // ===== 页面生命周期方法 =====
  2. onLoad: function () {
  3. // 从缓存获取任务列表数据,并用setData设置
  4. var todos = wx.getStorageSync('todo_list') // 调用 WX API 从本地缓存中获取数据
  5. if (todos) {
  6. var leftCount = todos.filter(function (item) {
  7. return !item.completed
  8. }).length
  9. this.setData({ todos: todos, leftCount: leftCount })
  10. }
  11. // 设置logs数据
  12. var logs = wx.getStorageSync('todo_logs')
  13. if (logs) {
  14. this.setData({ logs: logs })
  15. }
  16. },

onLoad: 页面加载 
一个页面只会调用一次。接收页面参数可以获取wx.navigateTo和wx.redirectTo及中的 query。 
setData: 接受一个对象,以 key,value 的形式表示将 this.data 中的 key 对应的值改变成 value。

三.事件处理函数

新增任务处理函数:

  1. addTodoHandle: function (e) {
  2. if (!this.data.input || !this.data.input.trim()) return
  3. this.setData( {
  4. addOneLoading: true
  5. });
  6. //open loading
  7. this.setData( {
  8. loadingHidden: false,
  9. loadingText: 'Waiting...'
  10. });
  11. var todos = this.data.todos
  12. todos.push({ name: this.data.input, completed: false })
  13. var logs = this.data.logs
  14. logs.push({ timestamp: new Date().toLocaleString(), action: '新增', name: this.data.input })
  15. this.setData({
  16. input: '',
  17. todos: todos,
  18. leftCount: this.data.leftCount + 1,
  19. logs: logs
  20. })
  21. this.save()
  22. },
  23. save: function () {
  24. wx.setStorageSync('todo_list', this.data.todos)
  25. wx.setStorageSync('todo_logs', this.data.logs)
  26. //close loading and toggle button loading status
  27. var self = this;
  28. setTimeout( function() {
  29. self.setData( {
  30. loadingHidden: true,
  31. addOneLoading: false,
  32. loadingText: ''
  33. });
  34. }, 100);
  35. },

主要把时间new Date().toLocaleString(), action:'新增',事件名 name: this.data.input这三个字段push到todos这个data数据中;然后在save()中通过wx.setStorageSync('todo_list', this.data.todos)设置缓存。

任务项点击状态切换函数:

  1. toggleTodoHandle: function (e) {
  2. var index = e.currentTarget.dataset.index
  3. var todos = this.data.todos
  4. todos[index].completed = !todos[index].completed
  5. var logs = this.data.logs
  6. logs.push({
  7. timestamp: new Date().toLocaleString(),
  8. action: todos[index].completed ? '标记完成' : '标记未完成',
  9. name: todos[index].name
  10. })
  11. this.setData({
  12. todos: todos,
  13. leftCount: this.data.leftCount + (todos[index].completed ? -1 : 1),
  14. logs: logs
  15. })
  16. this.save()
  17. },
  18. var index = e.currentTarget.dataset.index

获取当前索引,对应的wxml代码为:

  1. <view class="item{{ item.completed ? ' completed' : '' }}" wx:for="{{ todos }}" wx:key="{{ index }}" bindtap="toggleTodoHandle" data-index="{{ index }}">
  2. <!-- completed: success, todo: circle -->
  3. <icon class="checkbox" type="{{ item.completed ? 'success' : 'circle' }}"/>
  4. <text class="name">{{ item.name }}</text>
  5. <icon class="remove" type="clear" size="16" catchtap="removeTodoHandle" data-index="{{ index }}"/>
  6. </view>

bindtap: 当用户点击该组件的时候会在该页面对应的Page中找到相应的事件处理函数

最后考虑到了loading的效果,要利用button组件的loading属性来实现。但是loading仅仅是一个样式的控制,它不会控制这个按钮是否能重复点击。所以还要利用button的disabled属性,防止重复点击。

  1. <button type="primary" size="mini" bindtap="addTodoHandle" loading="{{addOneLoading}}" disabled="{{addOneLoading}}">
  2. + Add
  3. </button>

js:

  1. loadingChange: function() {
  2. this.setData({
  3. loadingHidden: true,
  4. loadingText: ''
  5. });
  6. },
  7. toastChange: function() {
  8. this.setData( {
  9. toastHidden: true,
  10. toastText: ''
  11. });
  12. }

LOGS页面比较简单,主要通过var logs = wx.getStorageSync('todo_logs') 
获取logs列表,然后在页面渲染,这里就不贴代码了。

至此,基本了解了TODOS应用的构建过程,通过代码详解、参考微信小程序官方文档了解了微信自家开发的视图层描述语言WXML和WXSS,以及基于 JavaScript 的逻辑层框架;与HTML页面结构相似,对应HTML,CSS,JAVASCRIPT; 所以学习起来比较容易。不过仅仅通过这个TODOS应用,还只是了解小程序这个平台的一些基本用法。复杂一点,页面跳转,网络请求等都需要我们去实践,才能对小程序了解得更多。

完整代码:

参考资料: 
1. 
2.

最新评论

zxj04 发表于 2022-7-6 16:48
立体播放器源码

轻源码让程序更轻更快

QingYuanMa.com

工作时间 周一至周六 8:00-17:30

侵权处理

客服QQ点击咨询

关注抖音号

定期抽VIP

Copyright © 2016-2021 https://www.171739.xyz/ 滇ICP备13200218号

快速回复 返回顶部 返回列表