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

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




推荐阅读
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 本文探讨了如何在 PHP 的 Eloquent ORM 中实现数据表之间的关联查询,并通过具体示例详细解释了如何将关联数据嵌入到查询结果中。这不仅提高了数据查询的效率,还简化了代码逻辑。 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • 本文探讨了在不使用服务器控件的情况下,如何通过多种方法获取并修改页面中的HTML元素值。除了常见的AJAX方式,还介绍了其他可行的技术方案。 ... [详细]
  • 本文详细介绍了 Apache Jena 库中的 Txn.executeWrite 方法,通过多个实际代码示例展示了其在不同场景下的应用,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 本文探讨了在UC浏览器中调用分享面板后,图片无法正常显示的问题,并提供了详细的解决方法和代码示例。 ... [详细]
  • 本文介绍了一种从与src同级的config目录中读取属性文件内容的方法。通过使用Java的Properties类和InputStream,可以轻松加载并获取指定键对应的值。 ... [详细]
  • FinOps 与 Serverless 的结合:破解云成本难题
    本文探讨了如何通过 FinOps 实践优化 Serverless 应用的成本管理,提出了首个 Serverless 函数总成本估计模型,并分享了多种有效的成本优化策略。 ... [详细]
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社区 版权所有