首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >在角5中使用RouterLink时,是否有任何方法禁用/防止“打开新选项卡/窗口”的选项?

在角5中使用RouterLink时,是否有任何方法禁用/防止“打开新选项卡/窗口”的选项?
EN

Stack Overflow用户
提问于 2020-02-10 02:25:36
回答 4查看 2.5K关注 0票数 0

我有一个单独的页面应用程序,并且使用锚标记()中的RouterLink导航到其他页面,而不需要刷新。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<ul class="menu">
          <li *ngIf="isContain(adminFilterMenuItems, 'Setup')">
            <a id="NavSetupButton" routerLink="/setup">
              <img alt="Setup" src="./assets/images/Setup.png" />
            </a>
          </li>
</ul>

我需要在右键上禁用一些选项,如“打开一个新选项卡”、“打开一个新窗口”等,而不是禁用整个上下文菜单,我需要上下文菜单。

我已经注意到,当我不使用RouterLink并实现其他逻辑导航时,我没有在右击中看到这些选项,这是我想要的。但是我使用的是RouterLink,并且不想为了这样的需求而搅乱整个应用程序。

在使用RouterLink进行导航时,是否可以在右键单击时禁用一些上下文菜单选项?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2020-02-13 02:36:58

我找到了一个适合我的解决办法。我没有使用RouterLink,而是调用click事件并编写了一个方法"navigateTo",因此这个单击事件将调用我的"navigateTo“方法,该方法将完成页面导航的工作。

HTML文件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<ul class="menu">
      <li *ngIf="isContain(adminFilterMenuItems, 'Setup')">
        <a id="NavSetupButton" (click)="navigateTo('/setup')">
          <img alt="Setup" src="./assets/images/Setup.png" />
        </a>
      </li>
</ul>

component.ts

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
  navigateTo(component) {
    this.router.navigate([component]);
  }
票数 0
EN

Stack Overflow用户

发布于 2020-02-10 05:57:27

右击中的选项列表称为上下文菜单。有多种方法来禁用它。前面提到的答案(oncontextmenu="return false;")是一个优雅的解决方案。

然而,由于这是一个与角度相关的问题,让我们编写一个属性指令:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import { Directive, HostListener } from '@angular/core';

@Directive({
  selector: '[appDisableRightClick]'
})
export class DisableRightClickDirective {
  @HostListener('contextmenu', ['$event']) onContextMenu($event: any) {
    $event.preventDefault();
  }
}

现在可以使用[routerLink]指令将其传递给锚标记。就像。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<a routerLink="sample" appDisableRightClick>About</a>

StackBlitz

在StackBlitz应用程序中,对于“关于”和“服务”的链接禁用上下文菜单,而链接“测试”是不修改的。

解释性HostListener装饰器声明要侦听的DOM事件,并提供了事件处理的方法。我们监听contextmenu事件,该事件通常是在单击鼠标右键或上下文菜单键时触发的。在实现中,调用事件的preventDefault()方法,该方法告诉浏览器不应该像通常那样采取默认操作。在我们的例子中,它禁止打开上下文菜单。

应用程序从这里分叉。

票数 1
EN

Stack Overflow用户

发布于 2020-02-10 02:28:57

请您在锚上尝试oncontextmenu事件,如下面的示例所示。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<a href="https://www.google.com" oncontextmenu="return false;"> Link </a>

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60148376

复制
相关文章
选项卡(TabHost)使用
使用方式: 从TabActivity中用getTabHost()方法获取TabHost,然后设置标签内容
李小白是一只喵
2020/04/24
1.8K0
选项卡
HTML代码 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>选项卡</title> <link rel="stylesheet" href="css/tab.css" /> </head> <body> <div id="tab"> <ul> <li class="select">视频</li
河湾欢儿
2018/09/05
1.5K0
Tab选项卡
实现步骤: 实现静态UI效果 用传统的方式实现标签结构和样式 基于数据重构UI效果 将静态的结构和样式重构为基于Vue模板语法的形式 处理事件绑定和js控制逻辑 声明式编程 模板的结构和最终显示的效果基本一致 1.html结构 <div id="app"> <div class="tab"> <!-- tab栏 --> <ul> <li class="acti
梨涡浅笑
2020/12/02
2.2K0
选项卡TabHost
1.布局 1 <TabHost xmlns:android="http://schemas.android.com/apk/res/android" 2 xmlns:tools="http://schemas.android.com/tools" 3 android:id="@+id/tabHost" 4 android:layout_width="match_parent" 5 android:layout_height="match_parent" > 6
欢醉
2018/01/22
1.6K0
选项卡TabHost
案例选项卡
案例:实现步骤 1. 实现静态UI效果 用传统的方式实现标签结构和样式 2. 基于数据重构UI效果 将静态的结构和样式重构为基于Vue模板语法的形式 处理事件绑定和js控制逻辑 3. 声明式编程
清出于兰
2020/12/01
1.5K0
案例选项卡
SetTimer在无窗口和有窗口线程的使用
 今天犯了一个粗心的错误,在无窗口线程中,SetTimer中设置计时器ID,而WM_TIMER消息响应函数中得到的计时器ID却不是之前设置的计时器ID.
雪影
2018/08/02
8280
js实现选项卡
选项卡就是点击按钮切换到相应内容,其实就是点击按钮把内容通过display(block none)来实现切换的。
wfaceboss
2019/04/08
2.8K0
在新窗口打开链接
最近博主再用H+模板时候表单提交和链接都在新窗口打开,没看见target="_blank",一直没查出来,苦恼N久,今天百度了如何用JS css等等实现网页所有链接在新窗口打开,终于找到了原因,因如下代码导致。 代码如下:
雨落凋殇
2019/12/25
2.7K0
Labview选项卡之实现被选择选项卡工作
有些时候,我们做界面,需要好多个界面切换。如果是同一个 VI 里界面切换,一般都是选项卡了。切换不同选项卡就切换界面了。
Gnep@97
2023/08/16
7681
Labview选项卡之实现被选择选项卡工作
html5新特性实现tab选项卡切换
分析代码可以知道,选项卡的class为active的时候,选项卡就被选中,当内容section的style属性为display:block时,内容就被选中
一个淡定的打工菜鸟
2018/09/06
12.9K6
Layui Tab 选项卡
layui-tab layui-tab-title layui-tab-content layui-tab-item
用户5760343
2019/10/24
3.3K0
小程序 — 选项卡
(2)将用户点击传过来的index值赋给data中改变当前的索引值activeIndex
Ewall
2018/09/30
1.6K0
小程序 — 选项卡
使用 jQuery 在新窗口打开外部链接
我们一般都希望在新窗口打开外部链接,这样用户就不需要离开网站就能访问外部链接,但是如果每个外部链接都手工加上新窗口打开的属性(target="_blank")的话,会让人非常抓狂。使用 jQuery,我们只需要几行代码就能在新窗口中打开外部链接。
Denis
2023/04/15
2.7K0
微信小程序----导航栏选项卡(MUI顶部选项卡)
效果图 WXML <import src="../../template/list.wxml"/> <view class="tui-tabbar-content"> <view class="
Rattenking
2021/02/01
1.6K0
微信小程序----导航栏选项卡(MUI顶部选项卡)
【说站】win10系统打开网页不是私密连接怎么解决?
我们平时上网在浏览器内打开某个网址时可能会遇到页面报错提示:“您的连接不是私密连接”,这种情况多是电脑上的时间日期设置的有问题导致证书过期失效或是网站不安全导致的。在您共享敏感信息时在线信息安全十分重要。那win10打开网页不是私密连接要怎么办呢?还不清楚的小伙伴们快跟着小编一起来看看解决方法吧!
很酷的站长
2022/11/24
10.6K0
【说站】win10系统打开网页不是私密连接怎么解决?
WordPress 网站如何有选择性的在新窗口打开链接?
WordPress 网站如何有选择性的在新窗口打开链接?在新窗口打开链接有时还是很有必要,下面这个简单实例,是利用 JQuery实现有选择性的在新窗口打开链接的方法。
主机教程网2bcd.com
2022/10/17
1K0
WPF实现选项卡效果(1)——使用AvalonDock
  公司最近一个项目,软件采用WPF开发,需要实现类似于VS的选项卡(或者是浏览器的选项卡)效果。搜寻诸多资料后,发现很多同仁推荐AvalonDock这款开源控件。在其官方地址下载源码和Demo后,对其进行了初步的研究,初步实现了预期效果。 完整系列   ● 第一部分   ● 第二部分   ● 第三部分 在Git中下载工程源码
全栈程序员站长
2022/09/13
1.6K0
WPF实现选项卡效果(1)——使用AvalonDock
微信小程序开发之选项卡(窗口顶部TabBar)页面切换
微信小程序开发中选项卡.在Android中选项卡一般用fragment,到了小程序这里瞬间懵逼了. 总算做出来了.分享出来看看. 先看效果:
李维亮
2021/07/09
1.3K0
使用 DevTools 新增的 Issues 选项卡发现网页问题
你是否有过被 Chrome 控制台的各种警告和错误支配的恐惧?大量的信息让我们难以找到网页的真正问题以及我们想要的信息。
ConardLi
2020/08/31
1.4K0
使用 DevTools 新增的 Issues 选项卡发现网页问题
点击加载更多

相似问题

防止在新选项卡/窗口中打开页

32

防止php在新选项卡/窗口中打开

12

防止在新选项卡/窗口中打开引导模式窗口

24

使用任何可能的方法在新选项卡(而不是新窗口)中打开

23

在silverlight中是否有任何方法打开带有某些html内容的新选项卡(或弹出窗口或窗口)?

13
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文