1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > 微信小程序开发实例总结

微信小程序开发实例总结

时间:2021-01-30 05:19:31

相关推荐

微信小程序开发实例总结

微信小程序|小程序开发

微信小程序开发小程序开发心得

微信小程序-小程序开发微信小程序 开发过程中遇到问题总结

openfire im 源码,ubuntu火狐启动不了,tomcat的中文参数报错,爬虫入门普通,php日期变成字符,seo教程入门seo公司lzw

第一次正式开发一个小程序,就从以下几个方面来谈一谈小程序的开发过程和心得吧,主要说说这次项目中用到的功能。

网狐手游平台源码,vscode的核心编辑器,ubuntu 后门设置,tomcat能通信吗,爬虫数据定义,webrtc php,seo免费和sem付费的区别,整形医院手机网站lzw

数据请求

长微博 源码,vscode设置命令行字体,ubuntu配置kde,web请求tomcat内存,爬虫电销,php框架特性,宜昌农业seo推广怎么做lzw

这次的小程序,没有太多的附加功能,所以数据以及对数据的处理是这次的主体工作,小程序向用户提供API,供用户向自己的服务器请求数据,值得一提的是,开发小程序之前,需要先在微信公众平台申请appID,并且绑定域名,域名必须是https协议,然后在小程序的开发工具的配置信息中完善信息,请求的地址需要在前面绑定的域名下。这个项目中用到wx.request从服务器拉取数据。

wx.request({ url: that.data.couponData.requestUrl, data: that.data.couponData.queryData, header: {content-type: application/json }, success: function(res) {var list = res.data.goodsList;console.log(res.data);for(var i in list) { list[i].quanUsedNum = parseInt(list[i].quanTotalNum) - parseInt(list[i].quanRemainNum);list[i].isImgRendered = false;} list[0].isImgRendered = list[1].isImgRendered = list[2].isImgRendered = list[3].isImgRendered = true;that.setData({"couponData.totalPage":res.data.totalPage});that.setData({"couponData.list":that.data.couponData.list.concat(list)}); that.setData({"couponData.loadmore":!that.data.couponData.loadmore});that.setData({"couponData.queryData.pageNum":parseInt(that.data.couponData.queryData.pageNum) + 1});if(that.data.couponData.queryData.pageNum > that.data.couponData.totalPage) {that.setData({"couponData.isAction":false}); } if(that.data.couponData.list.length < 1) {that.setData({"couponData.nodata":true}); }if(f) { f();} } });

数据缓存

这里使用数据缓存是因为需要做一个搜索功能,就涉及到页面之间的数据传递,放在地址中也是一种方法,借用一下localStorage也可以,使用wx.setStorage将数据存储到localStorage中,页面跳转之后,在从localStorage中读取就可以了,读取数据的时候分同步读取和异步读取。

剪切板的应用

借用小程序的API可以很方便的将任何信息复制到剪切板,然后就可以粘贴了。

wx.setClipboardData({ data: 【 + that.data.couponData.list[e.currentTarget.id].goodsTitle + 】复制这条信息,打开【手机淘宝】 + that.data.couponData.list[e.currentTarget.id].twoInOneKouling, success: function(res) {that.setData({"couponData.copyTip":true,"couponData.Kouling":that.data.couponData.list[e.currentTarget.id].twoInOneKouling}) } });

模板

在这个项目中,页面基本很相似,但有细微差别,所以就使用了模板,新建一个template/template.wxml,name属性必须要设置。

搜索

模块化

对于公共的js可以写在一个专门的js文件中,然后使用module.exports暴露接口。

通用的js文件使用require引入。

var common = require(../../common/common.js); ... common.f(); //调用

redirectTo & navigateTo

redirectTo是重定向至某页面,navigateTo是打开新的页面,值得说明的一点是,使用navigateTo打开的页面太多会导致小程序卡顿。

分享

Page({ onShareAppMessage: function () {return { title: your title!, path: /xxxx/xxxx/xxxx, //分享之后回到这个页面 success: function(res) { f(); //成功回调; }, fail: function(res) { f(); //失败回调; }} } })

提高列表滑动的流畅性

简而言之就是页面滚动到哪里,列表中的图片就显示到哪里,实现方法如下。

//js文件 Page({ loadImg:function(e) {//计算接下来加载哪几张var index = Math.floor((e.detail.scrollTop - 8)/259.5);var temp = this.data.couponData.list; //完整的列表var min = Math.max(index * 2,0),max = Math.min(index * 2 + 8,temp.length);for(var i = min; i < max; i ++) { if(temp[i] && !temp[i].isImgRendered) { temp[i].isImgRendered = true; //列表中的每一项有一个标记是否加载图片的的属性,默认false,随着页面滚动,一个个变成true。 }}this.setData({"couponData.list":temp});temp = null; }, }) //wxml文件中在scroll-view上绑定事件。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。