4007654355
NEWS
网站建设、网站制作、网站设计等相关资讯

微信小程序开发最佳实践

日期:2024-05-06 访问:131次 作者:admin

项目地址:https://github.com/skyFi/weapp-starter

为什么会有这个 repo

在小程序之初便开发应用了,现在小程序的开发也越来越成熟了,完善了很多的API、组件、架构等深圳市伟恒盛电子有限公司,社区也由原来的零星点点到现在的不大不小,但也算是有了,期间也诞生了很多的开发框架,越来越多的三方辅助库,我也捣鼓出很多。比较有名的算是wepylabradorwepyvue风格的小程序开发框架深圳市伟恒盛电子有限公司labrador 则比较亲和 React,各有千秋,也各有深坑,而 labrador 作者目前已经停止更新了 TnT,作为React深度使用者的我来说是忧伤的,于是我捣鼓出 wn-cli 来用类 React快速开深圳市伟恒盛电子有限公司发微信小程序,然而在这个过程中,想了很多,为什么需要开发框架呢?小程序本身在一开始就强调框架,且现在做的也不差,后来总结了下,无非是不熟悉小程序这套框架,但学习新的中间框架去开发小程序,这不是更加加大深圳市伟恒盛电子有限公司了熟悉成本吗?且出了问题增加了处理的代价。

于是,我重新思考了下,最佳的微信小程序开发实践应该是无痛的,且舒服的,无痛的是指在小程序的飞速发展变更中,我们不用重复的浪费学习第三方框架和原生框架。舒服的是深圳市伟恒盛电子有限公司指,我们能用上我们熟悉的流行工程流,如:less 预编译、async/await 异步请求,redux数据管理等。

以上,便是这个 repo 的意义与原因。

设计概要

[x] 优化小程序 API

Promise深圳市伟恒盛电子有限公司 化异步接口

突破请求数量限制(队列)

[x] 使用 async/await

[x] 接入 Redux 管理页面数据流

直接接入,添加可配置项

添加 saga 管理操作

[x] 样式书写采用 less 预编译

使用 Gulp管理自动深圳市伟恒盛电子有限公司编译,持续集成

[x] wxs 管理工具库

数据的格式化操作,如时间格式化、金币格式化等

[x] 按需加载,子页面分包(除却 tab 页面的其他页面)

按功能模块分包加载(推荐)

按 tab 分包

[x] 资源自动化管理

上传深圳市伟恒盛电子有限公司 CDN

Promise 化异步接口

由于微信的API中异步接口都是有三个回调函数的,分别是 successfailcomplete,执行时机同字面上意思( complete一定会在接口的最后执行)。于是结深圳市伟恒盛电子有限公司Promise,简单的描述如下(以下为简版,具体的可以看源码)。

原生微信小程序API:

wx.request({

// ... 其他一些配置项

 success: () => {},

fail: () => 深圳市伟恒盛电子有限公司{},

 complete: () => {}

});

添加 Promise后:

newPromise((resolve, reject) => {

 wx.request({

// ... 其他一些配置项

succes深圳市伟恒盛电子有限公司s: resolve,

   fail: reject,

   complete: resolve, // 这里暂取 resolve 来解决

 });

});

Promise 化后,使用起来就简单了:

wx.request({ /*深圳市伟恒盛电子有限公司 ...一些配置项 */}).then(res => {

 console.log(res)

}, err => {

 console.error(err)

})

结合下面的 async/await就可以更加方便的书深圳市伟恒盛电子有限公司写同步代码。

使用 async/await

1.添加 babel

yarn add babel-core

2.安装 env presets

yarn add babel-preset-env

3.使用 .babelrc

{深圳市伟恒盛电子有限公司

"presets": [

"env"

 ]

}

4.在 Gulp 中使用 babel

// install

yarn add gulp-babel

const babel = require(gulp-babel);

// .深圳市伟恒盛电子有限公司..

.pipe(babel())

// ...

5.添加 runtime,在使用 async/await的地方引入 ./src/utils/lib/runtime.js 文件,幸运的是这件事情在这个repo中的 G深圳市伟恒盛电子有限公司ulp任务中自动处理了。

以上,便可以在微信小程序中使用 async/await了。

样式书写采用 less 预编译

为什么选择 less,因为简单方便,前端编译,轻量级。

注意:由于小程序本身的限制,在书写样式的时深圳市伟恒盛电子有限公司候,不要使用less 的嵌套功能!

1.添加 less 变量库等

// ...

.pipe(addLessImport({

     themePath: path.join(__dirname, ./src/theme/深圳市伟恒盛电子有限公司index.less),

     commomPath: path.join(__dirname, ./src/app.less),

   }))

// ...

2.编译

// ...

.pipe(less({

paths: [p深圳市伟恒盛电子有限公司ath.join(__dirname,./src/theme)]

   }))

// ...

3.重命名样式文件,以便小程序识别

// ...

 .pipe(rename((path) => {

path.extname深圳市伟恒盛电子有限公司 =.wxss;

 }))

// ...

资源自动化管理

1.目前接入阿里云,监测 assert 文件夹,自动上传图片资源

2.根据配置自动生成 less 配置 config.less

gulp.src(src/them深圳市伟恒盛电子有限公司e/config.less, { allowEmpty: true })

   .pipe(file(config.less, `@cdn: ~${config.cdn};`))

   .pipe(changed(src深圳市伟恒盛电子有限公司/theme))

   .pipe(gulp.dest(src/theme))

3.使用

page {

 background-image: url(@{cdn}/index-bg.png);

background-a深圳市伟恒盛电子有限公司ttachment:fixed;

}

相关文章推荐

如何做一个小程序口令红包功能

写了一个时间管理的微信小程序

摩拜单车微信小程序开发技术总结

欢迎关注 SegmentFault 微信公众号 :)


标签:



相关文章: 网优工程师面试:精通信号处理,你如何优化网络覆盖?,陕西网站建设方案  SEO优化:快速提升网站排名,吸引海量流量  畅享免费AI,解锁无限语言魅力!  亚马逊北美开店注册方法是什么?  轻松免费推广,让网站火速走红!  智能纠错,写作更精炼  员工手册:我们的工作指南  突破SEO瓶颈,快速提升网站排名!  家电家具淘宝推广,家电家具信息发布系统  CRM软件新榜单:实力与口碑双优  百度招聘,职等你来!  “SEO神助手,流量翻倍神器”  “SEO关键词优化,快速增流秘籍”  语文试卷下载,哪位老师能分享下?,南京泰州seo招聘  抖音里的人怎么消失了?  2025两会前夕,哪位农民代表双倍收入梦?,台州建设网站公司  友情链接快速交易  SEO稳排,下拉无忧  外贸SEO优化:关键词布局+内容优化+链接建设  破局数字化营销,筑梦网络新未来  埃安送电到家 百人成团即可家门口建站解决小区充电难保姆小杨阿姨蹭大S流量,开启直播卖酸辣粉?看她的表情我牙酸了  抖音歌曲怎么搜不到?  八大战略是哪八大战略  焕新购物体验,尽在全新商城!  双营销方式,如何巧妙结合线上线下?,抖音营销推广过审流程图  新时代品牌新突破,创新营销赢未来。  “引擎优化,精准推广新利器”  我想自己做一个网站,大概流程是什么?我该怎么做?  高效外链策略,一招制胜!  刷淘宝人气安全吗?如何安全提升?  微商分销系统特点有哪些  产品亮点一触即发,效果究竟如何?,SEO优化专员方案  网页数据导出难题,速解攻略!  互联网口碑营销公司,哪家更胜一筹?,顺德seo方案  海阔凭鱼跃,天高任鸟飞?何方是归途?,网站建设哪家稳妥  网站建设哪家公司比较好?  太原市网络推广速成班  手机APP软件推广网站模板  淘宝频繁退货会有何后果?  SEO网站设计神器:快速提升排名流量  这手机全新,怎么卖?  做网站推广方案怎么设计才能怎样获得更多的客户关注?  品牌飞跃引擎,全网营销专家  oc工作是什么意思  基础学段  高效提升网站排名,策略精炼,一步到位  SEO头条:网站推广优化排名中值得深思的几个问题  一键查谷歌收录,高效SEO管理神器  快审备案网  应聘背调是什么意思 

豪情圣贤互联网技术服务 豪情圣贤互联网技术服务 豪情圣贤互联网技术服务 豪情圣贤互联网技术服务 豪情圣贤互联网技术服务 豪情圣贤互联网技术服务 豪情圣贤互联网技术服务 豪情圣贤互联网技术服务 豪情圣贤互联网技术服务 豪情圣贤网络服务 豪情圣贤网络服务 豪情圣贤网络服务 豪情圣贤科技 豪情圣贤科技 豪情圣贤科技