uniapp路由uni-simple-router使用示例

 更新时间:2023年07月10日 10:20:13   作者:小李不小  
这篇文章主要为大家介绍了uniapp路由uni-simple-router使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

正文

要在uniapp中使用路由守卫,uniapp原生的api是比较欠缺的,所以要用‘uni-simple-router’插件包

安装

// 项目根目录执行命令行  下载稳定版本  
npm install uni-simple-router@2.0.7 
// 根据pages.json总的页面,自动构建路由表
npm install uni-read-pages

配置

vue.config.js

注:如果根目录没有vue.config.js文件,要手动创建

// vue.config.js
const TransformPages = require('uni-read-pages')
const { webpack } = new TransformPages()
module.exports = {
    configureWebpack: {
        plugins: [
            new webpack.DefinePlugin({
                ROUTES: webpack.DefinePlugin.runtimeValue(() => {
                    const tfPages = new TransformPages({
                        includes: ['path', 'name', 'aliasPath','meta']
                    });
                    return JSON.stringify(tfPages.routes)
                }, true)
            })
        ]
    }
}

router文件夹下对应的 js文件

写如下代码

import { RouterMount, createRouter } from 'uni-simple-router';
const router = createRouter({
    platform: process.env.VUE_APP_PLATFORM,
    routes: [...ROUTES]
});
//全局路由前置守卫
router.beforeEach((to, from, next) => {
//权限控制登录
    if(to.meta.auth){
        console.log("需要登录");
        if("token"){
            next();
        }else{
            console.log("请登录");
        }
    }else{
        console.log("不需要登录");
         next();
    }
    console.log("前置守卫"+JSON.stringify(to));
});
// 全局路由后置守卫
router.afterEach((to, from) => {
    console.log('跳转结束')
})
export {
    router,
    RouterMount
}

main.js

import {router,RouterMount} from './router/router.js'  //路径换成自己的
Vue.use(router)
//v1.3.5起 H5端 你应该去除原有的app.$mount();使用路由自带的渲染方式
// #ifdef H5
    RouterMount(app,router,'#app')
// #endif
// #ifndef H5
    app.$mount(); //为了兼容小程序及app端必须这样写才有效果
// #endif

page.json

    "pages": [ //pages数组中第一项表示应用启动页,参考:https://uniapp.dcloud.io/collocation/pages
        {
            "path": "pages/index/index",
            "name": "index",
            "style": {
                "navigationBarTitleText": "uni-app"
            }
        }, {
            "path": "pages/home/home",
            "name": "home",
            "meta": {
                "auth": false, //需要登录
                "async": true, //是否同步
                "title": "首页", //标题
                "group": "商城" //分组
            },
            "style": {
                "navigationBarTitleText": "",
                "enablePullDownRefresh": false
            }
        },{
            "path": "pages/haha/haha",
            "name": "haha",
            "meta": {
                "auth": true, //需要登录
                "async": true, //是否同步
                "title": "首页", //标题
                "group": "商城" //分组
            },
            "style": {
                "navigationBarTitleText": "",
                "enablePullDownRefresh": false
            }
        }
    ],
    "globalStyle": {
        "navigationBarTextStyle": "black",
        "navigationBarTitleText": "uni-app",
        "navigationBarBackgroundColor": "#F8F8F8",
        "backgroundColor": "#F8F8F8"
    }
}

页面跳转和参数接收

push()

pushTab() : 跳转tar栏

replace() : 替换

replaceAll() : 替换所有

back() : 直接带上数字返回第几层

注意:path和query配合使用,而name和params配合使用

//通过name方式跳转
this.$Router.push({
                    name: 'home',
                    params: {
                        name: 'Joseph',
                        age: 22
                    }
                })
------------------------------------
//通过path形式进行跳转
this.$Router.push({
                     path: '/pages/haha/haha',
                        query: {
                            name: 'Josdep33333h',
                            age: 24
                        }
                })
-------------------------------------
//用uni形式跳转到新页面,并传递参数
uni.navigateTo({
                    url:'/pages/home/home?id=2&name=Josep33333h'
                });

获取参数

    onLoad(option) {
            //原生获取数据
                console.log("zz",option);
            // query传参
                const query=this.$Route.query
                console.log(query);
                // params传参
                const params=this.$Route.params
                console.log(params);
        }

以上就是uniapp路由uni-simple-router使用示例的详细内容,更多关于uniapp路由uni-simple-router的资料请关注脚本之家其它相关文章!

相关文章

  • php析构函数的具体用法小结

    php析构函数的具体用法小结

    本篇文章主要是对php析构函数的具体用法进行了详细的介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-03-03
  • 微信小程序实现的贪吃蛇游戏【附源码下载】

    微信小程序实现的贪吃蛇游戏【附源码下载】

    这篇文章主要介绍了微信小程序实现的贪吃蛇游戏,结合实例形式分析了微信小程序实现贪吃蛇游戏功能的相关界面布局与代码逻辑操作技巧,并附带源码供读者下载参考,需要的朋友可以参考下
    2018-01-01
  • js判断主流浏览器类型和版本号的简单实现代码

    js判断主流浏览器类型和版本号的简单实现代码

    下面小编就为大家带来一篇js判断主流浏览器类型和版本号的简单实现代码。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-05-05
  • JS DOM实现鼠标滑动图片效果

    JS DOM实现鼠标滑动图片效果

    这篇文章主要为大家详细介绍了JS DOM实现鼠标滑动图片效果,只要将鼠标放上该商品的区域,原本折叠起来的商品便会自动展开,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • 详解JavaScript中Promise类的使用方法

    详解JavaScript中Promise类的使用方法

    这篇文章主要为大家详细介绍了JavaScript中Promise类的使用方法,文中的示例代码简洁易懂,对我们学习JavaScript有一定的帮助,需要的可以参考一下
    2023-05-05
  • JavaScript基本语法学习教程

    JavaScript基本语法学习教程

    javascript语言是网页中广泛使用的一种脚本语言,通过本文给大家介绍javascript基本语法,需要的朋友可以参考下本文
    2016-01-01
  • js当月水电气简单计算器

    js当月水电气简单计算器

    一个可以计算当月水电气多少钱的计算器 说明:输入各项后,在页面任意空白处点击鼠标,页面自动计算一次结果!,每项都必须填写,填0也可以
    2008-04-04
  • 微信小程序实现图片上传

    微信小程序实现图片上传

    这篇文章主要为大家详细介绍了微信小程序实现图片上传,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-05-05
  • JS技巧之一行赋值语句能玩出多少花样

    JS技巧之一行赋值语句能玩出多少花样

    很多前端只会谢谢页面,一让他们接触js,就非常害怕,下面这篇文章主要给大家介绍了关于JS技巧之一行赋值语句能玩出多少花样的相关资料,需要的朋友可以参考下
    2022-10-10
  • js防刷新的倒计时代码 js倒计时代码

    js防刷新的倒计时代码 js倒计时代码

    这篇文章主要为大家详细介绍了js防刷新的倒计时代码,js倒计时的实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-09-09

最新评论