热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

微信小程序教学第二章(含视频):小程序中级实战教程之预备篇提取util公用方法...

iKcamp官网:www.ikcamp.com访问官网更快阅读全部免费分享课程:《iKcamp出品|全网最新|微信小程序&#

iKcamp官网:www.ikcamp.com

访问官网更快阅读全部免费分享课程:《iKcamp出品|全网最新|微信小程序|基于最新版1.0开发者工具之初中级培训教程分享》。 包含:文章、视频、源代码

第二章:小程序中级实战教程之预备篇

本文配套视频地址 v.qq.com/x/page/m055…

util公共方法

开始前请把 ch2-2 分支中的 code/ 目录导入微信开发工具


在这一章中,我们会在util目录新建 3 个文件,这些文件分别提供了一些常用的函数,变量,已便我们在不同的页面中使用

├── utils/ │ ├─ config.js│ ├─ index.js│ ├─ mock.js

Step 1.   config.js 配置常量

该文件存放了一些 const 常量(如开发环境,默认文案,默认图片等),将这些常量存在 core 这个对象中,最后通过 export default core 将 core 这个对象导出。由于只是存放一些配置常量,此处不再复述:

'use strict';const env = 'dev';// dev production/** 默认接口出错弹窗文案* @type {string}*/const defaultAlertMessage = '好像哪里出了小问题~ 请再试一次~';/** 默认分享文案* @type {{en: string}}*/const defaultShareText = {en: 'iKcamp英语-学英语口语听力四六级'};/** 小程序默认标题栏文字* @type {string}*/const defaultBarTitle = {en: 'iKcamp英语学习'};/** 文章默认图片* @type {string}*/const defaultImg = {articleImg: 'https://n1image.hjfile.cn/mh/2017/06/07/7e8f7b63dba6fa3849b628c0ce2c2a46.png',coverImg: 'https://n1image.hjfile.cn/mh/2017/06/07/7472c035ad7fe4b8db5d2b20e84f9374.png'};let core = {env: env,defaultBarTitle: defaultBarTitle['en'],defaultImg: defaultImg,defaultAlertMsg: defaultAlertMessage,defaultShareText: defaultShareText['en'],isDev: env === 'dev',isProduction: env === 'production'};export default core;

Step 2.   mock.js 数据

该文件用来存放一些假数据,方便本地开发调试,如果你有 mock 服务器,当然更好

const list = {data: [{articles: [{contentId: 1177432,cover: "https://n1image.hjfile.cn/mh/2017/06/26/9ffa8c56cfd76cf5159011f4017f022e.jpg",pubdate: "2017-06-27 00:45:00",title: "Quora精选:为什么聪明人总能保持冷静?"},{contentId: 1176561,cover: "https://n1image.hjfile.cn/mh/2017/06/26/0eb29c4c08e7be93f74ce9ce0fd5a25e.jpg",pubdate: "2017-06-27 00:30:00",title: "与时间有关的英语俚语(四)"},{contentId: 1161967,cover: "http://n1image.hjfile.cn/mh/2017/05/25/5d6ce79848cc81b800959383c35dd081.jpg",pubdate: "2017-06-27 00:15:00",title: "2017.5大学英语六级口语考试真题:看图论述“人与人之间的信任”"},{contentId: 1177828,cover: "https://n1image.hjfile.cn/mh/2017/06/26/c99a6d180367bf1a250d6e7c6c3083c6.jpg",pubdate: "2017-06-27 00:00:01",title: "亚马逊卖衣服有新招!新衣服试穿一周再付钱"}],date: "2017-06-27"},{articles: [{contentId: 1175100,cover: "https://n1image.hjfile.cn/mh/2017/06/23/2490fdbcfc131c0e256546da4a03f1ac.jpg",pubdate: "2017-06-26 00:45:00",title: "双语美文:小时候的自己,真是傻得可爱"},{contentId: 1172434,cover: "https://n1image.hjfile.cn/mh/2017/06/19/57a8ef65ee53f5921657376fd3fe4a75.jpg",pubdate: "2017-06-26 00:30:00",title: "15个和money有关的习语,可别用错了"},{contentId: 1161968,cover: "http://n1image.hjfile.cn/mh/2017/05/25/2260fb0deb74734f5ec5a375423a6b52.jpg",pubdate: "2017-06-26 00:15:00",title: "2017年5月大学英语六级口语考试真题——小组讨论之扶老人是我们的责任吗?"},{contentId: 1161963,cover: "http://n1image.hjfile.cn/mh/2017/05/25/93228c5713545ef328e708ddb73e28a2.jpg",pubdate: "2017-06-26 00:15:00",title: "2017年5月大学英语六级口语考试——优秀领导的特质"}],date: "2017-06-26"},{articles: [{contentId: 1175110,cover: "https://n1image.hjfile.cn/mh/2017/06/23/a5bf85e439696829a937accfd99f0eb7.jpg",pubdate: "2017-06-25 00:45:00",title: "Quora精选:什么样的人注定无法成功?"},{contentId: 1142849,cover: "https://n1image.hjfile.cn/mh/2017/06/22/faf544ccf3e4f9e8da4ee9d5d8fcc635.jpg",pubdate: "2017-06-25 00:30:00",title: "表达雌性动物和雄性动物的不同说法"},{contentId: 1161915,cover: "http://n1image.hjfile.cn/mh/2017/05/25/7778bd5547fa216db57cd87a78bd790d.jpg",pubdate: "2017-06-25 00:15:00",title: "2017年5月大学英语四级口语考试——如何用PPT展现一堂课"},{contentId: 1175101,cover: "https://n1image.hjfile.cn/mh/2017/06/23/045ed76502b0f1ccdaccdae827c17c2c.jpg",pubdate: "2017-06-25 00:00:00",title: "双语美文:总在不经意间,发觉自己渺小"}],date: "2017-06-25"}],message: "success",status: 0,time: null};const detail = {data: {agreeNum: 0,articleImage: "https://n1image.hjfile.cn/mh/2017/06/26/9ffa8c56cfd76cf5159011f4017f022e.jpg",author: "Quora用户",autoSummary: "Why do intelligent people seem calm all the time?为什么聪明人总能保持冷静?\r\n\r\n\t\r\n\r\n\tAnswer from @Domen Grabec来自@Domen Grabec的回答\r\n\r\n\tIf you can solve your problem, then what is the n...",cateId: 0,channelId: 1,commentCount: 2,content: '

\r\n\t

\r\n

\r\n\t

Why do intelligent people seem calm all the time?
为什么聪明人总能保持冷静?

\r\n

\r\n\t 

\r\n

\r\n\t

Answer from @Domen Grabec
来自@Domen Grabec的回答

\r\n

\r\n\t

If you can solve your problem, then what is the need of worrying?
如果你能解决问题,那何虑之有?

\r\n

\r\n\t

If you cannot solve it, then what is the use of worrying?
如果你不能解决问题,那忧虑又有什么用呢?

\r\n

\r\n\t

And if you look at this logically not being calm will only work to your disadvantage in many situations:
如果你从逻辑的角度来看,不冷静只会起反效果,在很多情况下都一样:

\r\n

\r\n\t

There is an important exam coming up and you are freaking out. Panicking might confuse you, inhibit your learning and as a result you might perform worse on the exam.
(比如)你正面临一场重要的考试,而你慌得不得了。你的惊慌只会让你思维混乱,它会妨碍你的学习,其结果就是你会在考试中发挥得更糟。

\r\n

\r\n\t

Someone is robbing you and you start to panic. You might get the robber nervous, and he might do something impulsive (like stab you) obviously worsening your position.
(再比如)一个人正在抢劫你,而你开始慌了。你可能会让抢劫者变得紧张,而他可能就会做出些过激的事情(比如捅你一刀),显然这回让你的处境更糟。

\r\n

\r\n\t

You lead a group of people at work and are facing a heavy problem, or an impossible deadline. Well this is the time to inspire people and get the most out of them as possible. That should increase your chances of solving the problem. If you panic you might discourage them, and not only you, but your whole team shall underperform.
(再比如)你正带领着一组人一起工作,并且正面临着一个严峻的问题,或者是一个不可能赶上的截止日期。好嘛,你现在需要做的是启发这些人,尽可能让他们做出成果;这会让你解决问题的概率更大一些。如果你慌了,你可能会打击到他们,于是不只是你,你的整个团队都会发挥不佳。

\r\n

\r\n\t

While you panic, your mind is having a hard time finding a solution to the problem. Even if the solution is only to stay calm and wait for the problem to pass.
当你慌张的时候,你的大脑会很难找到解决问题的方法。而解决问题的方法很有可能只是冷静下来并等着问题自己过去。

\r\n

\r\n\t 

\r\n

\r\n\t

Answer from @Faith Paul
来自@Faith Paul的回答

\r\n

\r\n\t

Intelligent people think before they speak.
聪明的人先想再说。

\r\n

\r\n\t

Intelligent people also think rationally.
而且,聪明人的思维是理性的。

\r\n

\r\n\t

Instead of freaking out over every little thing, finding drama, or becoming a victim, intelligent people rationalize their problems.
聪明人会理性地去分析问题,而不是在每个细枝末节上的慌神、制造情况、或怨天尤人。

\r\n

\r\n\t

Intelligent people don't prolong their problems. They end their suffering by doing what needs to be done in order for that problem to go away.
聪明人不会让问题遗留下来。他们会做那些必要的事以解决问题。

\r\n

\r\n\t

Additionally, I've noticed that intelligent people who are stressed find an outlet or take a nap. Bottling up anxiety or pointing fingers like many people do is just going to evoke more stress.
还有,我发现聪明人在不堪重负的时候会找个发泄方式,或者小憩一下。很多其他人或把焦虑压制下来,或者在别人身上出气,而这只会让压力更重。

\r\n

\r\n\t

Obviously not all problems can be solved, but my point is that intelligent people handle stress differently.
显然,并不是所有的问题都能被解决,我想表达的是:聪明人处理压力的方式时不一样的。

\r\n

\r\n\t
\r\n\t

\r\n

\r\n\t

Answer from @Humberto Rada
来自@Humberto Rada的回答

\r\n

\r\n\t

This could be for several reasons, but one thing I noticed from highly intelligent friends who are calm is that they are able to entertain themselves.
原因有很多,而我从我那些冷静的聪明朋友身上发现的一点是:他们有办法自娱自乐。

\r\n

\r\n\t

Yes that is right, they always got something to think about.
对,就是这样,他们总有什么东西可以想。

\r\n

\r\n\t

Its like they enjoy their thoughts more than interacting with other people.
好像他们觉得自己的思维比和人交流更有吸引力。

\r\n

\r\n\t

They are always elaborating on thoughts so they are busy with themselves.
他们总是在细细揣摩自己的想法,所以他们自己一个人忙着呢。

\r\n

\r\n\t 

\r\n

\r\n\t(翻译:能猫)

\r\n

\r\n\t声明:本双语文章的中文翻译系iKcamp英语原创内容,转载请注明出处。中文翻译仅代表译者个人观点,仅供参考。如有不妥之处,欢迎指正。

\r\n',contentId: 1177432,editorName: "能猫",isBest: "Y",langs: "en ",langsCate: 1043,langsParentCate: 1040,lastUpdateTime: "2017-06-27 00:45:00.530",link: "",maxPageNum: 1,newTitle: "",picName: "",reviewFlag: 0,sourceLink: "",sourceName: "Quora",sourceType: 0,sparePic: "",subTitle: "",subjectId: 0,summary: "为什么有些人总是有办法冷静地面对一切?",tags: "智力|职场|学习|双语阅读|励志人生|实用热门|quora|微信热门",title: "Quora精选:为什么聪明人总能保持冷静?",totalView: 112},message: "success",status: 0,time: null};export {detail,list}

Step 3.   增加 index.js 主入口文件

index.js 文件中,我们会增加一些公用的函数方法,比如对网络请求封装、开发环境下 log 日志、本地存储等

首先,我们把配置信息 config.js 和假数据 mock.js 引进来,并正常导出

'use strict'import Promise from '../lib/promise'import config from './config'import * as Mock from './mock'let util = {}export default util

第二行代码:

import Promise from '../lib/promise'

这一段代码的作用是引入一个实现 Promise 的 第三方工具库,这样我们就可以在小程序中使用 Promise 方法来解决 回调地狱 的问题。

注意: 在新版本的小程序中已经支持了原生 Promise 方法

下面我们开始对 util 对象进行公用方法扩展封装: 增加 log 控制台调试功能

如果环境配置为dev环境,则打印参数内容

let util = {isDEV: config.isDev,log(){this.isDEV && console.log(...arguments)}
}

封装 alert 弹出窗口

由于开发环境中,经常需要查看一些对象信息,所以增加了 object 类型解析

let util = {// 此处省略部分代码alert(title = '提示', content = config.defaultAlertMsg) {if ('object' === typeof content){content = this.isDEV && JSON.stringify(content) || config.defaultAlertMsg}wx.showModal({title: title,content: content})}
}

wx.showModal 是微信官方提供的 api 方法,具体用法可 查阅文档

封装本地缓存数据的读取功能

wx.getStorage 文档地址
wx.setStorage 文档地址

let util = {// 此处省略部分代码getStorageData(key, cb) {let self = this;// 将数据存储在本地缓存中指定的 key 中,会覆盖掉原来该 key 对应的内容,这是一个异步接口wx.getStorage({key: key,success (res) {cb && cb(res.data);}, fail (err) {let msg = err.errMsg || '';if( /getStorage:fail/.test(msg) ) {self.setStorageData(key)}}})},setStorageData(key, value = '', cb) {wx.setStorage({key: key,data: value,success() {cb && cb();}})}
}

上一篇-微信小程序教学第二章:小程序中级实战教程之预备篇 - 项目结构设计 |基于最新版1.0开发者工具

下一篇中,我们会把网络请求封装起来,并增加本地 mock 功能

iKcamp原创新书《移动Web前端高效开发实战》已在亚马逊、京东、当当开售。


相关文章: 听说 2017 你想写前端? 前端开发者指南(2017) 翻译连载 |《你不知道的JS》姊妹篇 | Javascript 轻量级函数式编程 翻译 | 关键CSS和Webpack: 减少阻塞渲染的CSS的自动化解决方案

iKcamp最新活动

报名地址:www.huodongxing.com/event/54099…

“天天练口语”小程序总榜排名第四、教育类排名第一的研发团队,面对面沟通交流。


2019年,iKcamp原创新书《Koa与Node.js开发实战》已在京东、天猫、亚马逊、当当开售啦!




推荐阅读
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Html5-Canvas实现简易的抽奖转盘效果
    本文介绍了如何使用Html5和Canvas标签来实现简易的抽奖转盘效果,同时使用了jQueryRotate.js旋转插件。文章中给出了主要的html和css代码,并展示了实现的基本效果。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文介绍了在Linux下安装Perl的步骤,并提供了一个简单的Perl程序示例。同时,还展示了运行该程序的结果。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
author-avatar
一号香久山日氵冥
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有