黔优媒体网-软文媒体自助发稿平台!
  1. 行业资讯
  2. 正文

微信小程序开发实例总结

来源:黔优媒体网   时间:2024-09-19

这篇文章主要介绍了微信小程序 开发过程中遇到问题总结的相关资料,需要的朋友可以参考下

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

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

数据请求

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

wx.request({
 url: that.data.couponData.requestUrl,
 data: that.data.couponData.queryData,
 header: {
 #39;content-type #39;: #39;application/json #39;
 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: #39;【 #39; + that.data.couponData.list[e.currentTarget.id].goodsTitle + #39;】复制这条信息,打开【手机淘宝】 #39; + 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属性必须要设置。

 template name= #39;navsearch #39; 
 view >

模块化

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

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

redirectTo & navigateTo

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

分享

 Page({
 onShareAppMessage: function () {
 return {
 title: #39;your title! #39;,
 path: #39;/xxxx/xxxx/xxxx #39;, //分享之后回到这个页面
 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上绑定事件。
 scroll-view >

以上就是微信小程序开发实例总结的详细内容,更多请关注php中文网其它相关文章!

微信app下载

微信是一款手机通信软件,支持通过手机网络发送语音短信、视频、图片和文字。微信可以单聊及群聊,还能根据地理位置找到附近的人,带给大家全新的移动沟通体验,有需要的小伙伴快来保存下载体验吧!


【免责申明】黔优媒体网以上展示内容来源于用户自主上传、合作媒体、企业机构或网络收集整理,版权争议与本站无关,文章涉及见解与观点不代表黔优媒体网官方立场,请读者仅做参考,本文标题:微信小程序开发实例总结;欢迎转载,转载时请说明出处。若您认为本文侵犯了您的版权信息,或您发现该内容有任何违法/违规的内容,请您立即联系我们及时修正或删除。(邮箱号: kefu@qianu.com)
此操作需要登录,请先登录~
免费注册会员,尽享国内领先平台!