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

小程序踩坑日记(一)

1.修改数据不成功page({data:{a:}})如果你想在methods里面调用你定义的a。应该用this.data.a;如果你想改变a必须要用this.setD

1.修改数据不成功

page({ data:{ a:'' } })

如果你想在methods里面调用你定义的a。应该用this.data.a ;
如果你想改变a 必须要用this.setData

this.setData({ a:b })

2.wx.request的post请求不成功

post请求一定要将'content-type' 改为 application/x-www-form-urlencoded。
此处官方解释为:最终发送给服务器的数据是 String 类型,如果传入的 data 不是 String 类型,会被转换成 String 。转换规则如下:
对于 header['content-type'] 为 'application/json' 的数据,会对数据进行 JSON 序列化
对于 header['content-type'] 为 'application/x-www-form-urlencoded' 的数据,会将数据转换成 query string (encodeURIComponent(k)=encodeURIComponent(v)&encodeURIComponent(k)=encodeURIComponent(v)...)

3.获取openid

openid 作为用户的唯一标示在小程序中扮演很重要的角色,当然我也在这个地方跳进了一个大坑;
一开始看网上的文章都是用‘https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code='+ code +'&grant_type=authorization_code’这个接口请求的,而且4个参数都很好获取,appid 和 密钥都是你自己知道的,code是在wx.login里面返回的,这个接口在本地开发的阶段是可以用的,但必须要不验证域名,做法是点击微信小程序右上方详情按钮,勾选不校验''合法域名项";我的问题是项目在做完后真机测试获取不到openid,后来才知道线上环境因为安全问题小程序不允许前端请求“https://api.weixin.qq.com”这个域名,所以必须要实现自己后台与微信后台的通信,就是你让你的后台去请求“https://api.weixin.qq.com”这个接口拿到openid,你去请求自己后台拿到openid,这样就是安全的啦。

4.冒泡事件

正常我们在标签中绑定事件用bindtap,微信给我们提供阻止事件冒泡的方法是用catchtap代替bindtap

5.wx.getUserInfo获取用户信息

这一部分当你初始化小程序的时候在app.js中就会有一段 wx.getSetting({}),在这个API里面调用wx.authorize(OBJECT),wx.authorize(OBJECT)用于提前向用户发起授权,调用后会立刻弹窗询问用户是否同意小程序使用某项功能或获取用户的某些数据;根据小程序服务内容不同,需要获得用户授权的内容就不同,官方提供了5中需要获得用户授权的功能
言归正传,到底怎么获取的用户信息呢?代码如下,这个也是借鉴网上的写法,原文,在跟自己的比较后还是觉得这个比较简洁,逻辑完整;

wx.getSetting({success: res => {if (res.authSetting['scope.userInfo']) {console.log('已经授权')// 已经授权,可以直接调用 getUserInfo wx.getUserInfo({success: res => {console.log('app.js执行 getUserInfo')// 可以将 res 发送给后台解码出 unionIdthis.globalData.userInfo = res.userInfo// 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回// 所以此处加入 callback 以防止这种情况if (this.userInfoReadyCallback) {this.userInfoReadyCallback(res)}}})}else{wx.getUserInfo({success: res => {console.log('app.js执行 getUserInfo2')// 可以将 res 发送给后台解码出 unionIdthis.globalData.userInfo = res.userInfo// 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回// 所以此处加入 callback 以防止这种情况if (this.userInfoReadyCallback) {this.userInfoReadyCallback(res)}}})}}
})

6.wx.uploadfile()上传多张图片

官方提供的wx.uploadFile 只能一次上传一张图片,项目如果需要上传多张图片怎么办呢,这是我在网上找的解决方法uploadFile上传多张图片. 我的项目还涉及了打开手机相册选取图片,图片预览等需求,这里用到的两个API 是wx.chooseImage()和wx.previewImage();这里建议大家可以看一下weui提供的写法,weui是一个很靠近微信设计的UI库,下载地址;我的用法是下载.zip到本地后解压,然后将dist目录作为项目的根目录进行浏览就可以了

7.下拉刷新

下拉刷新无效,这时你要在app.json 中添加一个配置
需要刷新的页面的配置中也需要添加,例如index.js中要用到刷新,你可以在index.json 中配置
这样基本就可以实现下拉刷新了

onPullDownRefresh: function () {wx.stopPullDownRefresh();wx.request({url: 'https://......',success: function (res) {}});
}

onPullDownRefresh监听下拉刷新,你会发现下拉后一直出现刷新动画,这时只要添加wx.stopPullDownRefresh()就可以停止刷新动画了,刷新处理数据的逻辑写在wx.stopPullDownRefresh()下方

自己写到这里先告一段落,以后还会继续开发小程序,以后遇到的问题也会总结出来跟大家分享交流,自己写这篇文章的初衷是给在开发过程中遇到和我一样问题的你提供一些参考,很多都是借鉴别人的方法,我在文章中也添加了原文地址,勿喷。如果有错误可以指出,我会重新改正的。




推荐阅读
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文探讨了在不使用服务器控件的情况下,如何通过多种方法获取并修改页面中的HTML元素值。除了常见的AJAX方式,还介绍了其他可行的技术方案。 ... [详细]
  • 本文介绍了如何使用PHP代码实现微信平台的媒体素材上传功能,详细解释了API接口的使用方法和注意事项,确保文件路径正确以避免常见的错误。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • 本文探讨了如何在 PHP 的 Eloquent ORM 中实现数据表之间的关联查询,并通过具体示例详细解释了如何将关联数据嵌入到查询结果中。这不仅提高了数据查询的效率,还简化了代码逻辑。 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 本文详细介绍了如何使用PHP检测AJAX请求,通过分析预定义服务器变量来判断请求是否来自XMLHttpRequest。此方法简单实用,适用于各种Web开发场景。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 深入理解Tornado模板系统
    本文详细介绍了Tornado框架中模板系统的使用方法。Tornado自带的轻量级、高效且灵活的模板语言位于tornado.template模块,支持嵌入Python代码片段,帮助开发者快速构建动态网页。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本文探讨了如何优化和正确配置Kafka Streams应用程序以确保准确的状态存储查询。通过调整配置参数和代码逻辑,可以有效解决数据不一致的问题。 ... [详细]
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社区 版权所有