uniapp开发小程序-工作笔记
创始人
2024-02-28 06:20:12
0

开发背景

公司开始安排本人开发微信小程序,于是乎研究了一点关于uniapp的api和注意的点。仅仅是个人笔记…可能有错误,希望各位指出。

uniapp开发小程序

应用生命周期

onLaunch 初始化完成时 只触发一次

onShow 后台进入前台 显示页面的时候

onHide 前台进入后台 隐藏页面的时候显示

onError uni报错时

页面生命周期

onInit 页面初始化 参数等同onLoad,早于onLoad

onLoad 页面加载 参数为上个页面传递的参数

onShow 每次页面显示,包括下级页面返回

onReady 页面初始化渲染完成

onHide 页面隐藏

onUnload 页面卸载

onResize 窗口尺寸变化

小程序登录流程

在这里插入图片描述

如果在页面同时使用了vue 的生命周期

则顺序关系是created->onLoad->onShow->mounted

onLoad调用uni.login()进行微信登录,获取code

小程序设置顶部导航背景图片

"pages": [ //pages数组中第一项表示应用启动页{"path": "pages/login/index","style": {"navigationStyle": "custom"   //这个就使之自定义结构了}},]

uniapp存取本地

uni.setStorageSync('longitude', res.longitude);
uni.getStorageSync('token')

uniapp登录

uni.login({provider: 'weixin',success: (res) => {if ("login:ok" === res.errMsg) {that.code = res.code}},});

uniapp获取授权

uni.getSetting({success(res) {if (res.authSetting['scope.userLocation']) {// 再次判断所需权限是否已授权,如已授权则直接使用uni.getLocation({success(res) {console.log(res)}})} else if (!res.authSetting['scope.userLocation']) {// 如未授权则重新打开设置页面,进行授权uni.showModal({//弹出提示框title: '是否打开设置页?',content: '需要在设置中获取地址信息和定位权限',success(res) {if (res.confirm) {// 用户点击确定按钮uni.openSetting({// 确认后打开设置页面success(res) {if (res.authSetting['scope.userLocation']) {this.longitude = res.longitudethis.latitude = res.latitude} else {console.log("手动授权失败")}},fail() {console.log("打开设置页面失败")}})} else if (res.cancel) {// 用户点击取消按钮console.log('用户点击取消');}},fail() {console.log("确认取消弹出未弹出")}});}},fail(e) {console.log("获取已授权信息失败",e)}})

uniapp获取用户信息

之前的getuserInfo不能用了,每次都会弹窗,用户确认允许后才可以拿到用户信息

let that = thisuni.getUserProfile({desc: "weixin", // 指明用途,这个参数是必须的success: function(res) {uni.setStorageSync("userInfo", res.userInfo)}})

uniapp全局变量

例如:在App.vue中,与生命周期同级声明变量,只能命名为globalData。
在其他页面中getApp().globalData.text = 'test'进行读写
在App.vue本文件中this.globalData.systemTitle = res.title如此读写

uniapp调用客户端api出错,这个代码意味着当前账户开发者并非属于项目开发者

errMsg: "getSetting:fail "
err_code: -80002

小程序分享按钮

比如可以写在onLaunch

uni.showShareMenu({withShareTicket:true,//设置下方的Menus菜单,才能够让发送给朋友与分享到朋友圈两个按钮可以点击menus:["shareAppMessage","shareTimeline"]})

小程序监听跳转

比如写在onShow

uni.addInterceptor('navigateTo', { //监听跳转invoke(args) {const url = args.url.split('?')[0]that.watchRouter(url);},success(url) {console.log("获取地址",url)// that.watchRouter(url);}})uni.addInterceptor('redirectTo', { //监听关闭本页面跳转invoke(args) {const url = args.url.split('?')[0]that.watchRouter(url);},success(e) {// that.watchRouter(e);}})uni.addInterceptor('switchTab', { //监听tabBar跳转invoke(args) {const url = args.url.split('?')[0]that.watchRouter(url);},success(e) {// that.watchRouter(e);}})uni.addInterceptor('navigateBack', { //监听返回invoke(args) {const url = args.url.split('?')[0]that.watchRouter(url);},success(e) {that.watchRouter(e);}})

小程序截取query参数

			splitParams(url) {//只要问号后面的字符串var arr = url.split('?')var params = arr[1];var arr1 = params.split('&');var obj = {}//因为arr1里面有多个元素,都要切割,所以我们需要遍历循环。for (var i = 0; i < arr1.length; i++) {var newArr = arr1[i].split('=');obj[newArr[0]] = newArr[1];}return obj;;},	

uniapp获取经纬度

uni.getLocation({type: 'wgs84',geocode: true,success: (res) => {this.longitude = res.longitudethis.latitude = res.latitudeuni.setStorageSync('longitude', res.longitude);uni.setStorageSync('latitude', res.latitude);}});

相关内容

热门资讯

常用商务英语口语   商务英语是以适应职场生活的语言要求为目的,内容涉及到商务活动的方方面面。下面是小编收集的常用商务...
六年级上册英语第一单元练习题   一、根据要求写单词。  1.dry(反义词)__________________  2.writ...
复活节英文怎么说 复活节英文怎么说?复活节的英语翻译是什么?复活节:Easter;"Easter,anniversar...
2008年北京奥运会主题曲 2008年北京奥运会(第29届夏季奥林匹克运动会),2008年8月8日到2008年8月24日在中华人...
英语道歉信 英语道歉信15篇  在日常生活中,道歉信的使用频率越来越高,通过道歉信,我们可以更好地解释事情发生的...
六年级英语专题训练(连词成句... 六年级英语专题训练(连词成句30题)  1. have,playhouse,many,I,toy,i...
上班迟到情况说明英语   每个人都或多或少的迟到过那么几次,因为各种原因,可能生病,可能因为交通堵车,可能是因为天气冷,有...
小学英语教学论文 小学英语教学论文范文  引导语:英语教育一直都是每个家长所器重的,那么有关小学英语教学论文要怎么写呢...
英语口语学习必看的方法技巧 英语口语学习必看的方法技巧如何才能说流利的英语? 说外语时,我们主要应做到四件事:理解、回答、提问、...
四级英语作文选:Birth ... 四级英语作文范文选:Birth controlSince the Chinese Governmen...
金融专业英语面试自我介绍 金融专业英语面试自我介绍3篇  金融专业的学生面试时,面试官要求用英语做自我介绍该怎么说。下面是小编...
我的李老师走了四年级英语日记... 我的李老师走了四年级英语日记带翻译  我上了五个学期的小学却换了六任老师,李老师是带我们班最长的语文...
小学三年级英语日记带翻译捡玉... 小学三年级英语日记带翻译捡玉米  今天,我和妈妈去外婆家,外婆家有刚剥的`玉米棒上带有玉米籽,好大的...
七年级英语优秀教学设计 七年级英语优秀教学设计  作为一位兢兢业业的人民教师,常常要写一份优秀的教学设计,教学设计是把教学原...
我的英语老师作文 我的英语老师作文(通用21篇)  在日常生活或是工作学习中,大家都有写作文的经历,对作文很是熟悉吧,...
英语老师教学经验总结 英语老师教学经验总结(通用19篇)  总结是指社会团体、企业单位和个人对某一阶段的学习、工作或其完成...
初一英语暑假作业答案 初一英语暑假作业答案  英语练习一(基础训练)第一题1.D2.H3.E4.F5.I6.A7.J8.C...
大学生的英语演讲稿 大学生的英语演讲稿范文(精选10篇)  使用正确的写作思路书写演讲稿会更加事半功倍。在现实社会中,越...
VOA美国之音英语学习网址 VOA美国之音英语学习推荐网址 美国之音网站已经成为语言学习最重要的资源站点,在互联网上还有若干网站...
商务英语期末试卷 Part I Term Translation (20%)Section A: Translate ...