当前位置: 首页 > news >正文

elementUI的el-menu组件做内部组件和外链区分

场景:左侧菜单栏的菜单项有内部组件切换,也会有点击后进入外链的情况,如何同时处理这种情况?

解决思路:

  1. 在路由配置中path代表组件切换路径或者外链配置
  2. el-menu-item显示菜单项时,使用动态路由形式,判断如果是组件切换,使用is为router-link组件,to为path,如果是外链,使用a标签形式,path为href即可;
  3. 如果判断是否为外链,正则匹配是否以/^(https?:|mailto:|tel:)/.test(path)即可

路由配置:

{// 'path': '/activity','path': 'https:www.baidu.com','name': 'activity','component': Activity
}

AppLink封装:插槽形式显示el-menu-item

<template><!-- 通过动态组件显示,如果是外链显示a标签,如果是基础路由显示router-link --><!-- 这里直接使用v-bind="isExternalLink(to)"会报错,需要在上面加入一行注释:eslint-disable vue/require-component-is --><!-- eslint-disable vue/require-component-is --><component v-bind="isExternalLink(to)"><slot></slot></component>
</template>
<script>
import { Validator } from "@bigbighu/cms-utils";
export default {name: "AppLink",props: {to: {type: String,required: true}},methods: {isExternalLink(url) {// /^(https?:|mailto:|tel:)/.test(path)if (Validator.isExternal(url)) {return {is: "a",href: url,target: "_blank",rel: "noopener"};}return {is: "router-link",to: url};}}
};
</script>

 el-menu-item使用:

  <!-- 判断是否是外链 --><app-link v-if="child.redirect != 'noRedirect' &&  child.meta" :to="resolvePath(child.path)"><el-menu-item v-if="child && child.meta" :index="resolvePath(child.path)"><i class="el-icon-setting"></i><span slot="title">{{child.meta.title }}</span></el-menu-item></app-link>

http://www.lryc.cn/news/222418.html

相关文章:

  • 使用Ruby编写通用爬虫程序
  • 231108 C语言中是否可以函数内部动态申请内存,再传给外部变量?
  • 基于飞迪RTK/INS组合导航模组的里程计发布方法
  • 无mac电脑获取app的公钥的方法
  • 【Mybatis源码】反射 – TypeParameterResolver
  • Drogon源码剖析
  • maven 上传本地jar包到nexus
  • 聊一聊,今年参加软考高级的一些总结
  • 【寒武纪(4)】图像处理硬件加速,基于CNCVE
  • 有关python库
  • java项目之电影网站(ssm框架)
  • 技术分享 | app自动化测试(Android)--触屏操作自动化
  • Java连接数据库并查询表中的全部数据
  • STM32存储左右互搏 SPI总线读写FLASH W25QXX
  • 【EI会议征稿】第四届计算机网络安全与软件工程国际学术会议(CNSSE 2024)
  • 解决pip 安装 pyhash错误
  • 解决 win11 vmware 中centos 网络不能访问外网
  • Flutter vs 前端 杂谈:SliverAppBar、手动实现Appbar、前端Html+JS怎么实现滚动变化型Appbar - 比较
  • Qt 二维码生成与识别
  • jacoco和sonar
  • Django系列之Serializer的source参数使用、自定义序列化方法
  • Java从入门到精通
  • 电路布线问题动态规划详解(做题思路)
  • webpack 的 Loader 和 Plugin 的区别,常见的 loader 和 plugin 有哪些?
  • 云计算实战项目之---学之思在线考试系统
  • 研究生学术与职业素养讲座MOOC---期末复习(1-15)
  • kube-prometheus-stack监控k8s1.24+ docker缺少图像
  • 【C/PTA——循环结构3】
  • MAC设备(M1)环境下编译安装openCV for Java
  • pytest中的pytest.ini