桂峰乡小程序入门就看这篇
阅读 29240 · 发布日期 2020-08-24 17:26 · 温州优光网络科技有限公司|建站|APP小程序制作|做网站SEO推广优化
【摘要】
说明文章为实战中踩坑经历,以及解决方案。同时是自己的一个项目回顾,在这里分享给大家,希望能帮助到大家,如果觉得文章对你有用,请点个赞,谢谢!原谅我也是个标题党:)登录授权授权(基本信息,手机号码 )必须使用小程序原生的的button组件,然后指定open-type 后通过回调才能拿到用户信息。代码入下:index.wx... 【温州小程序开发,温州微信公众号,平阳做网站,平阳网站建设公司,平阳小程序商城制作,昆阳万全做网站,鳌江水头小程序,萧江腾蛟微信公众号,山门顺溪南雁海西南麂凤卧麻步怀溪网络网店服务,政采云网店管理服务】...
说明文章为实战中踩坑经历,以及解决方案。
同时是自己的一个项目回顾,在这里分享给大家,希望能帮助到大家,如果觉得文章对你有用,请点个赞,谢谢!原谅我也是个标题党:
)登录授权授权(基本信息,手机号码 )必须使用小程序原生的的button组件,然后指定open-type 后通过回调才能拿到用户信息。
代码入下:
index.wxml
// ... data: {
hasUserInfo: false, canIUse: wx.canIUse('
button.open-type.getUserInfo'
), userInfo: {
}
, getUserInfo: false, getPhone: false, hasAuth: false }
, onLoad: async function () {
var that = this;
// 查看是否授权 wx.getSetting({
success: function (res) {
if (res.authSetting['
scope.userInfo'
]) {
wx.login({
success: loginRes => {
// 获取到用户的 code 之后:
loginRes.code wx.getUserInfo({
success: async function (res) {
// 这里处理业务逻辑 }
}
) }
}
) }
else {
// 用户没有授权 }
}
}
);
}
, bindGetUserInfo: function (e) {
// 需要什么信息都从e中拿到 以下部分业务逻辑 if (e.detail.userInfo) {
//用户按了允许授权按钮 var that = this;
// 获取到用户的信息 wx.login({
success: async res => {
const aUserModel = new UserModel();
const params = {
code: res.code, encryptedData: e.detail.encryptedData, iv: e.detail.iv }
const {
data }
= await aUserModel.login({
...params }
) if(data.roles){
// do ... }
if (data.mobile) {
// do ... }
}
}
);
//授权成功后,通过改变 isHide 的值,让实现页面显示出来,把授权页面隐藏起来 that.setData({
isHide: false }
);
}
else {
//用户按了拒绝按钮 wx.showModal({
title: '
警告'
, content: '
拒绝授权,您将无法使用小程序'
, showCancel: false }
);
}
}
, getPhoneNumber: async function (e) {
if (e.detail.encryptedData) {
//用户按了允许授权按钮 const aUserModel = new UserModel();
const params = {
userId: userInfo.id, encryptedData: e.detail.encryptedData, iv: e.detail.iv }
// do ... }
else {
//用户按了拒绝按钮 wx.showModal({
title: '
警告'
, content: '
拒绝授权,您将无法使用小程序'
, showCancel: false }
) }
}
, // ... }
)路由路由跳转的各个方法可以去官网学习,这里提遇到的坑,navigateTo路由跳转最多只能10层,所以使用的时候需要考虑是不是确定需要历史记录。
为什么要这么说呢。
场景:
一个列表页面(如下图),用户的档案是可以修改的,如果用navigateTo跳转(/page/archivesEdit?id=1923XXXX),修改保存用navigateTo(/page/archivesList),这样来回编辑跳转10次就不让点击跳转了。
解决:
思考那我用2个redirectTo 行不行?redirectTo是关闭当前历史记录跳转到下一页面。
造成了我跳转到修改页面点击微信自带的返回是直接跳过列表页面跳转到首页。
这个时候测试小姐姐就又要提bug单了。
。
。
完美姿势:
就是用navigateTo和navigateBack。
我再编辑保存的时候返回用navigateBack返回。
这样小程序的路由栈就一会在2-3层之间。
当然有时候在列表页面会遇到要重新调用接口,这时候路由跳转提供了几个重要的钩子函数onShow,onHide,我们可以在onShow的时候可以调用一下列表的接口。
这2个钩子函数足够我们简单的跳转,更复杂的场景下可以通过存Storage这种存取参数来返回到上一个页面进行操作,感觉不是优雅,但是没有好的办法解决了。
Storage场景:
storage有2种方式获取,当你直接wx.getStorageSync('
xxx'
)获取一个id,去请求接口的可能是获取不到就已经发送请求了,导致出现bug。
因为wx.getStorageSync('
xxx'
)是异步的 我们可以利用 async/await去方便的使用onLoad: async function (options) {
const editListParams = await wx.getStorageSync('
editListParams'
) this.findReportDetails(editListParams) }
webViewwebview不是在某个页面使用的,当时我以为是类似iframe这种东西嵌入到页面。
正确的使用态度是新建一个page页面,然后跳转到这个page去使用。
例如跳转到小程序关联的公众号文章:
other.wxml
大家可自行参考如下封装ajax.js import {
baseURL }
from '
../config/interfaceURL'
// baseUrl class AJAX {
AJAX ({
url, methods = '
GET'
, data = {
}
}
) {
return new Promise((resolve, reject) => {
this.request(url, resolve, reject, methods, data) }
) }
request (url, resolve, reject, methods, data) {
wx.request({
url: baseURL + url, method: methods, data: data, header: {
'
content-type'
: '
application/json'
}
, success: res => {
const code = res.statusCode.toString() if (code.startsWith('
2'
)) {
resolve(res) }
else {
reject() const errorMessage = res.data.message AJAX.showError(errorMessage) }
}
, fail: err => {
reject() AJAX.showError("网络异常,请稍后重试!") }
}
) }
static showError (errorMessage) {
wx.showToast({
title: errorMessage, icon: '
error'
, duration: 2000 }
) }
static serializeLink (obj) {
// 序列化get请求 let temp = '
?'
for (let index in obj) {
if(obj.hasOwnProperty(index)){
temp += (index + '
='
+ obj[index] + '
&'
) }
}
return temp.substr(0, temp.length - 1) }
}
export default AJAX // model层调用 UserModel.js import AJAX from '
../utils/AJAX'
export class UserModel extends AJAX {
// 小程序授权登陆 login (params) {
return this.AJAX({
url: `/service/api/users/applet/login`, data: params, methods: '
POST'
}
) }
}
// control调用 index.js async onLoad (options){
const aUserModel = new UserModel() const params = {
code: loginRes.code, encryptedData: res.encryptedData, iv: res.iv }
const {
data }
= await aUserModel.login({
...params }
) // 其他 }
npm生态以及第三方ui框架直接通过初始化的微信小程序项目里面没有package.json文件。
所以在使用npm install xxx 是没有卵用。
所以我们要自己在文件夹根目录下执行npm init 。
这时候才能通过微信开发者工具构建npm,构建成功会生成一个目录。
推荐用有赞的vant小程序版,社区较活跃,使用起来不会有很多坑。
双向绑定对于习惯使用vue的开发者来说,少了这个v-model语法糖。
在处理表单的双向绑定会显得比较蛋疼。
所以还是有必要说下小程序里面的双向绑定是怎么样的。
file:index.js Page({
data: {
list: [] }
, onLoad: function (options) {
// do ... }
, onInput (e) {
let value = e.detail.value let temp = e.target.dataset.name.split('
,'
) let tempKey = temp[1] let tempIndex = temp[0] let tempSubIndex = temp[2] let targetKey = `list[${
tempIndex}
].children[${
tempSubIndex}
].${
tempKey}
` this.setData({
[targetKey]: value }
) }
}
) file:index.wxml
savePhoto () {
const _this = this;
wx.getImageInfo({
src: '
/static/images/home/Qr.png'
, success: function (res) {
wx.saveImageToPhotosAlbum({
filePath: res.path, success (result) {
_this.setData({
show: false }
);
wx.showToast({
title: '
保存成功'
, icon: '
success'
, duration: 2000 }
) }
, fail (err) {
if (err.errMsg === "saveImageToPhotosAlbum:fail auth deny") {
wx.openSetting({
success (settingdata) {
if (settingdata.authSetting['
scope.writePhotosAlbum'
]) {
_this.savePhoto() }
else {
wx.showToast({
title: '
获取权限失败,无法保存图片'
, icon: '
success'
, duration: 2000 }
) }
}
}
) }
}
}
) }
}
) }
保存图片也是需要授权的,看代码就完事了。
其他textarea 在ios上表现会有padding值。
我曹 这个就坑了。
我采用要不全是textarea或者全是input 这种去实现表单的填写。
其他样式问题也蛮多的,有点ie的味道。
!! 多用flex float去解决一些差异吧~结语文章每个点都是开发小程序的时候遇到的问题,本人能力有限,欢迎大家在评论区提问题交流学习,也可以关注好享家公众号获取更多优质文章。
推荐教程:
《微信小程序》以上就是小程序入门就看这篇的详细内容,更多请关注php中文网其它相关文章!
微信
分享相关标签:
微信小程序本文转载于:
掘金社区,如有侵犯,请联系a@php.cn删除
上一篇:
小程序之picker 数据是 Object Array
下一篇:
小程序图片如何铺满整个屏幕?相关文章相关视频微信小程序知识点总结自学微信小程序从零到一:
项目构建后http请求封装微信小程序-canvas生成图片并保存到本地怎样将微信小程序发送到桌面?小程序入门就看这篇微信小程序事件 以及事件对象初识微信小程序(1)初识微信小程序(3) [温州做小程序]