微信小程序开发二
1.获取用户信息
1.微信小程序获取用户基本信息的几种方式
2.wx.getUserInfo(Object object)
3.微信小程序获取openid的两种方法 两种方式实现获取用户信息。
4.小程序登录 登录凭证校验。通过 wx.login 接口获得临时登录凭证 code 后传到开发者服务器调用此接口完成登录流程。
2.自动切换环境配置
在小程序开发的时候,需要配置是否校验接口域名,在后台进行了配置之后,也还是可以进行请求的,但是如果要在本地进行配置自动切换怎么做呢?经过我多次查看,主要有两个地方去判断
- (1)调用 wx.getSystemInfoSync() 函数,获取其中的信息判断 host 值,在开发者工具中这个值不存在(存疑)。
- (2)调用 wx.getAccountInfoSync() 接口,判断 envVersion 值,
2023年09月12日,好像还是不行,到目前为止还是只能手动修改接口地址,然后提交审核。
1.微信小程序:本地开发环境和线上环境配置 这里通过调用 wx.getSystemInfoSync() 获取host,判断有没有,但是实际上在开发者工具中,这个值也是存在的。
2.原生小程序根据当前版本自动切换 开发版本、体验版本、正式版本 接口地址 这个在提审时有跟问题,提审的版本会认为是develop版导致请求的数据是测试版的。然后被审核拒绝。
3.Object wx.getAccountInfoSync() 获取当前账号信息。线上小程序版本号仅支持在正式版小程序中获取,开发版和体验版中无法获取。
4.【陈年BUG】能否解决小程序审核版调用wx.getAccountInfoSync()获取env的问题 这个问题一直到 2023年09月12日好像还是没有解决,就是在审核的时候,还是返回了 develop 这个状态,而不是 release 状态。
5.wx.getSystemInfoSync() 开发工具获取不到host 真机调试有但是没appid?
3.短信链接跳转到小程序
(1) 生成小程序的URL Scheme,进入小程序管理后台,选择“工具-生成URL Scheme”。
这个生成 URL Scheme 的功能进行了调整,变成了从后端生成。除此之外,还多加了很多的限制:
1.每个 URL Scheme 或 URL Link 有效期最长 30 天,均不再支持永久有效的链接、不再区分短期有效链接与长期有效链接;
2.链接生成后,若在微信外打开,用户可以在浏览器页面点击进入小程序。每个独立的链接被用户访问后,仅此用户可以再次访问并打开对应小程序,其他用户无法再次通过相同链接打开该小程序;
3.单个小程序每天生成链接数(URL Scheme 和 URL Link 总数)上限为 50 万条。
(2) 编写网页将URL Scheme填入其中,比如:
1 | location.href = 'weixin://dl/business/?ticket= *TICKET*' |
(3) 发送一个h5的网页链接给用户,链接中填写网页的url地址。
(4) 用户点击短信中的url,跳转到网页,然后从网页打开微信小程序。
1.短信链接跳转微信小程序的三种方式
2.短信链接点击跳转到微信小程序
3.微信小程序新能力:URL Scheme,可从短信跳转小程序 这里提供了一个网页内容,可以直接使用。
4.小程序后台工具下拉没有生成URL Scheme
5.小程序链接生成与使用规则调整公告 这个公告也是一片骂声啊
6.获取scheme码
4.获取用户位置
(1)getLocation
通过 getLocation 获取用户的位置信息。
(2)onLocationChange
通过 onLocationChange 监听用户位置变动的方法,结合 starLocationUpdate 使用
1 | const _locationChangeFn = (res) => { |
(3) 全局配置app.json
1 | "requiredPrivateInfos": [ |
1.wx.onLocationChange搭配wx.startLocationUpdate的使用方法 这个简单,就是调用了 onLocationChange 和 offLocationChange 方法。
2.微信小程序 使用 wx.onLocationChange() 这是有一个例子,使用了异步的方法进行获取。
3.全局配置
4.接口未正确配置:wx.getLocation,但是我正确配置了,怎么搞?
5.引入第三方组件
以安装moment.js为例。
(1)安装 momnet.js
1 | npm install moment --save |
(2) 点击微信开发者工具菜单栏,选择工具->构建 npm,进行构建,然后在工程目录下,就有了 miniprogram_npm 文件,里面包含了需要的依赖包。
(3) 引用 moment.js
1 | import moment from 'moment' |
6.封装wx.request为同步
很多的东西都是异步的,之后我暂时用了回调函数的方式进行统计的。
1.微信小程序开发之异步转同步
2.将小程序原生异步函数promisify后,在async/await中使用
3.微信小程序:封装wx.request同步请求
4.微信小程序封装wx.request请求
7.云开发
微信云开发,每一个月都要最基础的也要19块钱的费用,后来我就干脆直接关闭了,直接用后台数据库好了。关闭云开发
(1)首先打开云开发控制台
(2)进入控制台后,选择“设置”
(3)在设置里点击环境名称,再点击“管理我的环境”
(4)会在右侧打开环境管理,点击删除即可
(5)再用管理员微信扫码确认下就行了,
1.微信小程序如何关闭云开发