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

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




推荐阅读
  • 本文介绍了如何利用Struts1框架构建一个简易的四则运算计算器。通过采用DispatchAction来处理不同类型的计算请求,并使用动态Form来优化开发流程,确保代码的简洁性和可维护性。同时,系统提供了用户友好的错误提示,以增强用户体验。 ... [详细]
  • 在JavaWeb开发中,文件上传是一个常见的需求。无论是通过表单还是其他方式上传文件,都必须使用POST请求。前端部分通常采用HTML表单来实现文件选择和提交功能。后端则利用Apache Commons FileUpload库来处理上传的文件,该库提供了强大的文件解析和存储能力,能够高效地处理各种文件类型。此外,为了提高系统的安全性和稳定性,还需要对上传文件的大小、格式等进行严格的校验和限制。 ... [详细]
  • 优化后的标题:深入探讨网关安全:将微服务升级为OAuth2资源服务器的最佳实践
    本文深入探讨了如何将微服务升级为OAuth2资源服务器,以订单服务为例,详细介绍了在POM文件中添加 `spring-cloud-starter-oauth2` 依赖,并配置Spring Security以实现对微服务的保护。通过这一过程,不仅增强了系统的安全性,还提高了资源访问的可控性和灵活性。文章还讨论了最佳实践,包括如何配置OAuth2客户端和资源服务器,以及如何处理常见的安全问题和错误。 ... [详细]
  • Tornado框架中模块与静态文件的应用
    本文详细介绍了Tornado框架中模块和静态文件的使用方法。首先明确模块与模板的区别,然后通过具体的代码示例展示如何在HTML文档中使用模块,并配置模块的路由。最后,提供了模块类中参数获取的示例。 ... [详细]
  • 微信公众号推送模板40036问题
    返回码错误码描述说明40001invalidcredential不合法的调用凭证40002invalidgrant_type不合法的grant_type40003invalidop ... [详细]
  • 深入解析 Lifecycle 的实现原理
    本文将详细介绍 Android Jetpack 中 Lifecycle 组件的实现原理,帮助开发者更好地理解和使用 Lifecycle,避免常见的内存泄漏问题。 ... [详细]
  • 本地存储组件实现对IE低版本浏览器的兼容性支持 ... [详细]
  • 本文介绍了如何使用 Node.js 和 Express(4.x 及以上版本)构建高效的文件上传功能。通过引入 `multer` 中间件,可以轻松实现文件上传。首先,需要通过 `npm install multer` 安装该中间件。接着,在 Express 应用中配置 `multer`,以处理多部分表单数据。本文详细讲解了 `multer` 的基本用法和高级配置,帮助开发者快速搭建稳定可靠的文件上传服务。 ... [详细]
  • 在尝试对 QQmlPropertyMap 类进行测试驱动开发时,发现其派生类中无法正常调用槽函数或 Q_INVOKABLE 方法。这可能是由于 QQmlPropertyMap 的内部实现机制导致的,需要进一步研究以找到解决方案。 ... [详细]
  • DVWA学习笔记系列:深入理解CSRF攻击机制
    DVWA学习笔记系列:深入理解CSRF攻击机制 ... [详细]
  • 本文深入解析了WCF Binding模型中的绑定元素,详细介绍了信道、信道管理器、信道监听器和信道工厂的概念与作用。从对象创建的角度来看,信道管理器负责信道的生成。具体而言,客户端的信道通过信道工厂进行实例化,而服务端则通过信道监听器来接收请求。文章还探讨了这些组件之间的交互机制及其在WCF通信中的重要性。 ... [详细]
  • C++ 异步编程中获取线程执行结果的方法与技巧及其在前端开发中的应用探讨
    本文探讨了C++异步编程中获取线程执行结果的方法与技巧,并深入分析了这些技术在前端开发中的应用。通过对比不同的异步编程模型,本文详细介绍了如何高效地处理多线程任务,确保程序的稳定性和性能。同时,文章还结合实际案例,展示了这些方法在前端异步编程中的具体实现和优化策略。 ... [详细]
  • 在多线程并发环境中,普通变量的操作往往是线程不安全的。本文通过一个简单的例子,展示了如何使用 AtomicInteger 类及其核心的 CAS 无锁算法来保证线程安全。 ... [详细]
  • 第二十五天接口、多态
    1.java是面向对象的语言。设计模式:接口接口类是从java里衍生出来的,不是python原生支持的主要用于继承里多继承抽象类是python原生支持的主要用于继承里的单继承但是接 ... [详细]
  • 在本文中,我们将详细介绍如何构建一个用于自动回复消息的XML类。当微信服务器接收到用户消息时,该类将生成相应的自动回复消息。以下是具体的代码实现:```phpclass We_Xml { // 代码内容}```通过这个类,开发者可以轻松地处理各种消息类型,并实现高效的自动回复功能。我们将深入探讨类的各个方法和属性,帮助读者更好地理解和应用这一技术。 ... [详细]
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社区 版权所有