热门标签 | 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()下方

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




推荐阅读
  • 本文介绍如何使用 Angular 6 的 HttpClient 模块来获取 HTTP 响应头,包括代码示例和常见问题的解决方案。 ... [详细]
  • Python + Pytest 接口自动化测试中 Token 关联登录的实现方法
    本文将深入探讨 Python 和 Pytest 在接口自动化测试中如何实现 Token 关联登录,内容详尽、逻辑清晰,旨在帮助读者掌握这一关键技能。 ... [详细]
  • 本文介绍了如何使用JavaScript的Fetch API与Express服务器进行交互,涵盖了GET、POST、PUT和DELETE请求的实现,并展示了如何处理JSON响应。 ... [详细]
  • Java项目分层架构设计与实践
    本文探讨了Java项目中应用分层的最佳实践,不仅介绍了常见的三层架构(Controller、Service、DAO),还深入分析了各层的职责划分及优化建议。通过合理的分层设计,可以提高代码的可维护性、扩展性和团队协作效率。 ... [详细]
  • 黑马头条项目:Vue 文章详情模块与交互功能实现
    本文详细介绍了如何在黑马头条项目中配置文章详情模块的路由、获取和展示文章详情数据,以及实现关注、点赞、不喜欢和评论功能。通过这些步骤,您可以全面了解如何开发一个完整的前端文章详情页面。 ... [详细]
  • 在高并发需求的C++项目中,我们最初选择了JsonCpp进行JSON解析和序列化。然而,在处理大数据量时,JsonCpp频繁抛出异常,尤其是在多线程环境下问题更为突出。通过分析发现,旧版本的JsonCpp存在多线程安全性和性能瓶颈。经过评估,我们最终选择了RapidJSON作为替代方案,并实现了显著的性能提升。 ... [详细]
  • 微信小程序:授权登录与手机号绑定
    本文详细介绍了微信小程序中用户授权登录及绑定手机号的流程,结合官方指引和实际开发经验,提供了一套完整的实现方案,帮助开发者更好地理解和应用。 ... [详细]
  • 本文探讨了在 SQL Server 中使用 JDBC 插入数据时遇到的问题。通过详细分析代码和数据库配置,提供了解决方案并解释了潜在的原因。 ... [详细]
  • Kubernetes 持久化存储与数据卷详解
    本文深入探讨 Kubernetes 中持久化存储的使用场景、PV/PVC/StorageClass 的基本操作及其实现原理,旨在帮助读者理解如何高效管理容器化应用的数据持久化需求。 ... [详细]
  • 在创建新的Android项目时,您可能会遇到aapt错误,提示无法打开libstdc++.so.6共享对象文件。本文将探讨该问题的原因及解决方案。 ... [详细]
  • 本文介绍如何在Spring Boot项目中集成Redis,并通过具体案例展示其配置和使用方法。包括添加依赖、配置连接信息、自定义序列化方式以及实现仓储接口。 ... [详细]
  • 我有一个SpringRestController,它处理API调用的版本1。继承在SpringRestControllerpackagerest.v1;RestCon ... [详细]
  • 深入理解Vue.js:从入门到精通
    本文详细介绍了Vue.js的基础知识、安装方法、核心概念及实战案例,帮助开发者全面掌握这一流行的前端框架。 ... [详细]
  • 在PHP后端开发中遇到一个难题:通过第三方类文件发送短信功能返回的JSON字符串无法解析。本文将探讨可能的原因并提供解决方案。 ... [详细]
  • ElasticSearch 集群监控与优化
    本文详细介绍了如何有效地监控 ElasticSearch 集群,涵盖了关键性能指标、集群健康状况、统计信息以及内存和垃圾回收的监控方法。 ... [详细]
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社区 版权所有