uniapp开发App——登陆流程 判断是否登陆,是,进入首页,否,跳转到登录页

一、登陆流程

文字描述:用户进入App,之后就是判断该App是否有用户登陆过,如果有,直接进入首页,否则跳转到登陆页,登陆成功后,进入首页。

流程图如下:

二、在uniapp项目中代码实现

实现逻辑:

  1. 前提准备:登录页、首页、在pages.json里配置App展示的第一个页面就是首页

  2. 在app.vue页面的 onLaunch 方法中,判断用户是否登陆

html 复制代码
<script>
	export default {
		onLaunch: function() {
			console.log('App Launch')
            //通过本地缓存取出登陆的凭证
			let loginValue = uni.getStorageSync("isLoginKey");
            //如果没有登陆,就跳转到登陆页,如果已经登陆过,那就默认,会直接展示首页
			if (!loginValue) {
                //跳转进入登录页
				uni.reLaunch({
					url: "/pages/login/login",
					success: () => {}
				})
			} 
		},
		onShow: function() {
			console.log('App Show')
		},
		onHide: function() {
			console.log('App Hide')
		},
	}
</script>

<style>

</style>

做到这里,实际操作中,都会发现, 进入App时,都会先进入首页,我们往往能看到它存在的一瞬间,这个体验非常差,接下来解决该问题

三、解决显示登录页前,会看到首页存在的一瞬间

原理:

利用App splash(启动封面)遮挡住那一瞬间,那么用户就看不到了。

Splashscreen的基础知识看官方文档manifest.json 应用配置 | uni-app官网

实现逻辑:

  1. 将启动封面Splashscreen的默认配置修改。

alwaysShowBeforeRender = false

autoclose = false

=》因为我要手动控制启动封面什么时候关闭,所以不然它自动关闭。

1. 在manifest.json的源码试图中修改启动封面Splashscreen配置

这样启动封面就不会消失,无法看到App里面的内容。

2. 延时手动调用关闭App封面,让跳转的一瞬间发生时,App还停留在显示启动封面

html 复制代码
<script>
	export default {
		onLaunch: function() {
			console.log('App Launch')
			let loginValue = uni.getStorageSync("isLoginKey");
            //关闭启动封面,当然它要延迟1秒
			this.closeSplashscreen();
			if (!loginValue) {
				uni.reLaunch({
					url: "/pages/login/login",
					success: () => {}
				})
			} 
		},
		onShow: function() {
			console.log('App Show')
		},
		onHide: function() {
			console.log('App Hide')
		},
		methods: {
			closeSplashscreen: function() {
				// #ifdef APP-PLUS
				setTimeout(() => {
                    //手动关闭App启动封面
					plus.navigator.closeSplashscreen()
				}, 1000)
				// #endif
			}
		}
	}
</script>

四、优化:在未登录情况下,首页跳转到登陆的速度

原理:设置登录页,跳转无动画

javascript 复制代码
//pages.json
	{
			"path": "pages/login/login",
			"style": {
				"navigationBarTitleText": "",
				"navigationStyle": "custom",
				"app-plus": {
					"bounce": "none",//页面回弹效果取消
					"animationType": "none", //关闭动画
					"animationDuration": "none" //关闭动画
				}
			}
		},
相关推荐
懒大王952716 分钟前
uni-app + Vue3 + EZUIKit.js 播放视频流
开发语言·javascript·uni-app
懒大王952720 分钟前
uni-app + Vue3 开发展示 echarts 图表
前端·uni-app·echarts
百思可瑞教育3 小时前
Vue 生命周期详解:从初始化到销毁的全过程剖析
前端·javascript·vue.js·前端框架·uni-app·北京百思可瑞教育·百思可瑞教育
jingling5556 小时前
uniapp | 快速上手ThorUI组件
前端·笔记·前端框架·uni-app
百思可瑞教育12 小时前
uni-app 根据用户不同身份显示不同的tabBar
vue.js·uni-app·北京百思可瑞教育·北京百思教育
Q_Q196328847519 小时前
python+springboot+uniapp微信小程序题库系统 在线答题 题目分类 错题本管理 学习记录查询系统
spring boot·python·django·uni-app·node.js·php
百思可瑞教育20 小时前
使用UniApp实现一个AI对话页面
javascript·vue.js·人工智能·uni-app·xcode·北京百思可瑞教育·百思可瑞教育
不想吃饭e21 小时前
在uniapp/vue项目中全局挂载component
前端·vue.js·uni-app
00后程序员张1 天前
iOS App 混淆与资源保护:iOS配置文件加密、ipa文件安全、代码与多媒体资源防护全流程指南
android·安全·ios·小程序·uni-app·cocoa·iphone
不知名的前端专家1 天前
uniapp原生插件 TCP Socket 使用文档
网络·tcp/ip·uni-app·netty