IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 添加:Uniapp的H5项目(vue-cli创建)的全局路由拦截器uni-simple-router(共3步)。 -> 正文阅读

[JavaScript知识库]添加:Uniapp的H5项目(vue-cli创建)的全局路由拦截器uni-simple-router(共3步)。

第1步:下载路由拦截器插件uni-simple-router和自动构建路由表插件uni-read-pages。

npm install uni-simple-router@2.0.6
npm install uni-read-pages

第2步:在src->router目录下新建index.js

// router/index.js
import { RouterMount,createRouter } from 'uni-simple-router';
import store from "@/store/index.js" 

const whiteList = ['/pages/index/index', '/pages/404/404']

const getUserInfo = () => {
	store.dispatch('getUserInfoDataFromApp') // 因是H5嵌入APP的项目,需从APP获取用户信息。
}

const router = createRouter({
	platform: process.env.VUE_APP_PLATFORM, // vue-cli创建项目的相关环境变量文件里面的变量,可能是区分平台使用,不是太重要。
	routes: [...ROUTES] // 安装uni-read-pages插件后,系统读取pages.json文件后,会自动生成ROUTES数组变量
});

// 全局路由:前置守卫
router.beforeEach((to, from, next) => {
	if (store.state.userInfo.token) {
		next()
	} else {
		if (whiteList.includes(to.path)) {
			next()
		} else {
			getUserInfo()
			store.state.userInfo.token ? next() : next({path: '/pages/404/404', NAVTYPE: 'replaceAll'})
		}
	}
});

// 全局路由:后置守卫
router.afterEach((to, from) => {
	console.log('全局路由后置守卫')
})

export {
	router,
	RouterMount
}

?第3步:修改main.js文件即可。( 修改步骤:import引入路由->use安装路由->执行RouterMount()函数)

????????注:不需要修改APP.vue文件。(尤其是不能往App.vue中添加template元素,会导致其他问题,暂不清楚导致原因&解决)

// main.js
import Vue from 'vue'
import App from './App'

import {router,RouterMount} from './router'
Vue.use(router)

import uView from "uview-ui";
import constVariable from '@/utils/const'
import store from './store'

Vue.prototype.$c = constVariable
Vue.prototype.$store = store
Vue.prototype.$toast = (title) => 
{  
	uni.showToast({
		title,
		icon: "none",
		duration: 2000 
	});
}
Vue.use(uView);

Vue.config.productionTip = false

App.mpType = 'app'
const app = new Vue({
    ...App
})

// v1.3.5起 H5端 你应该去除原有的app.$mount(); 使用路由自带的渲染方式
// #ifdef H5
	RouterMount(app,router,'#app')
// #endif

// #ifndef H5
	app.$mount(); //为了兼容小程序及app端必须这样写才有效果
// #endif
<!-- App.vue -->
<!-- [重BUG]: 引入template后,出现uni.showToast和uni.showLoading不能使用,控制台报错$vm of undefined问题。 -->
<!-- <template>
	<div id="app">
		<u-no-network></u-no-network>
		<router-view />
	</div>
</template> -->
<script>
	export default {
		onLaunch: function() {
			console.log('App onLaunch')
		},
		onShow: function() {
			console.log('App Show')
		},
		onHide: function() {
			console.log('App onHide')
		},
		globalData: {
			
		},
		methods: {
			commonSetTimeOut(callback){
				this.timer = setTimeout(() => {
					callback && callback()
				}, 300)
			}
		}
	}
</script>

<style lang="scss">
	/* 每个页面公共css */
	/* 注意要写在第一行,同时给style标签加入lang="scss"属性 */
	@import "uview-ui/index.scss";
	@import "./styles/common.scss";
	@import "./static/font/iconfont.css";
	/* 页面主窗口背景颜色: 类似body元素 */
	page{
		background-color: #F5F5F5;
		color: $uni-text-color;
		position: relative;
		font-family: PingFangSC-Regular, PingFang SC;
	}
	// 订单的搜索筛选项
	.u-dropdown__menu__item /deep/ .u-flex {
		border: 1rpx solid #CCC;
		padding: 8rpx 24rpx;
		font-weight: bold;
	}
	.empty-wrap {
		padding-top: 50% !important;
	}
	.flex {
		display: flex;
		justify-content: flex-start;
	}
</style>

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-24 14:50:47  更:2021-10-24 14:53:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 17:22:38-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码