微信小程序 实例开发总结


Posted in Javascript onApril 26, 2017

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

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

数据请求

这次的小程序,没有太多的附加功能,所以数据以及对数据的处理是这次的主体工作,小程序向用户提供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属性必须要设置。

<template name='navsearch'>
 <view class='nav-search'>
   <view class='nav-search__container space-between'>
     <view class='nav-search__search' wx:if='{{isSearch}}'></view>
     <input class='nav-search__input' placeholder='请输入关键词找券' name='queryStr' value="{{queryStr}}" bindfocus='toggleSearch' bindconfirm='doQuery' bindinput="syncQuery"/>
     <view class='nav-search__delete' wx:if='{{!isSearch}}' bindtap='deleteAll'></view>
     <view class='nav-search__btn center' wx:if='{{!isSearch}}' bindtap='doQuery'>搜索</view>
   </view>

   <view class='nav-filter' bindtap='toggleFilter'></view>
 </view>
 </template>

 <!--在其他文件中使用模板-->
 <import src="/template/template.wxml" />
 <template is='navsearch' data="{{...couponData}}"></template>

模块化

对于公共的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上绑定事件。
 <scroll-view class="section" scroll-y="true" bindscroll='loadImg'></scroll-view>

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
jquery插件之easing 动态菜单
Aug 21 Javascript
javascript结合ajax读取txt文件内容
Dec 05 Javascript
jQuery如何获取动态添加的元素
Jun 24 Javascript
js中获取键盘事件的简单实现方法
Oct 10 Javascript
Angular.js中$resource高大上的数据交互详解
Jul 30 Javascript
Vue 拦截器对token过期处理方法
Jan 23 Javascript
IE8中jQuery.load()加载页面不显示的原因
Nov 15 jQuery
layui按条件隐藏表格列的实例
Sep 19 Javascript
浅谈VUE中演示v-for为什么要加key
Jan 16 Javascript
关于IDEA中的.VUE文件报错 Export declarations are not supported by current JavaScript version
Oct 17 Javascript
element el-table表格的二次封装实现(附表格高度自适应)
Jan 19 Javascript
Vue监视数据的原理详解
Feb 24 Vue.js
AngularJS 霸道的过滤器小结
Apr 26 #Javascript
JavaScript纯色二维码变成彩色二维码
Jul 23 #Javascript
xmlplus组件设计系列之按钮(2)
Apr 26 #Javascript
xmlplus组件设计系列之列表(4)
Apr 26 #Javascript
JS实现数组按升序及降序排列的方法
Apr 26 #Javascript
详解AngularJs ui-router 路由的简单介绍
Apr 26 #Javascript
JS ES6多行字符串与连接字符串的表示方法
Apr 26 #Javascript
You might like
PHP写杨辉三角实例代码
2011/07/17 PHP
Thinkphp模板中截取字符串函数简介
2014/06/17 PHP
php session_decode函数用法讲解
2019/05/26 PHP
js nextSibling属性和previousSibling属性概述及使用注意
2013/02/16 Javascript
Jquery图片延迟加载插件jquery.lazyload.js的使用方法
2014/05/21 Javascript
node.js中实现kindEditor图片上传功能的方法教程
2017/04/26 Javascript
vue2.0 中#$emit,$on的使用详解
2017/06/07 Javascript
jquery实现放大镜简洁代码(推荐)
2017/06/08 jQuery
Vue上传组件vue Simple Uploader的用法示例
2017/08/25 Javascript
vue 组件 全局注册和局部注册的实现
2018/02/28 Javascript
js中数组常用方法总结(推荐)
2019/04/09 Javascript
Layui多选只有最后一个值的解决方法
2019/09/02 Javascript
JavaScript点击按钮生成4位随机验证码
2021/01/28 Javascript
一个超级简单的python web程序
2014/09/11 Python
python实现的系统实用log类实例
2015/06/30 Python
在django中使用自定义标签实现分页功能
2017/07/04 Python
tensorflow创建变量以及根据名称查找变量
2018/03/10 Python
python对于requests的封装方法详解
2019/01/03 Python
Python scrapy增量爬取实例及实现过程解析
2019/12/24 Python
浅谈keras使用中val_acc和acc值不同步的思考
2020/06/18 Python
美国领先的礼品卡网站:GiftCards.com
2016/11/02 全球购物
中国高端家电购物商城:顺电
2018/03/04 全球购物
Kathmandu新西兰官网:新西兰户外运动品牌
2019/07/27 全球购物
音乐表演专业毕业生求职信
2013/10/14 职场文书
新闻专业推荐信范文
2013/11/20 职场文书
2013届毕业生求职信范文
2013/11/20 职场文书
大一军训感言
2014/01/09 职场文书
合同协议书格式
2014/04/18 职场文书
校园演讲稿汇总
2014/05/21 职场文书
2014年服装销售工作总结
2014/11/27 职场文书
2019年励志签名:致拼搏路上的自己
2019/10/11 职场文书
解析Java中的static关键字
2021/06/14 Java/Android
解决mysql模糊查询索引失效问题的几种方法
2021/06/18 MySQL
如何利用 CSS Overview 面板重构优化你的网站
2021/10/24 HTML / CSS
游戏《东方异文石:爱亚利亚黎明》正式版发布
2022/04/03 其他游戏
Win11如何默认打开软件界面最大化?Win11默认打开软件界面最大化的方法
2022/07/15 数码科技