Когда вы CTRL+щелкните или нажмите на средний щелчок элемент боковой панели:
Англуна все еще обновляет [(ActiveId)] через событие Click, запускаемое Ngbnavlink, хотя маршрут не изменился.
Это вызывает синий фон (активный стиль), чтобы применить к Clicked Menu Ittem в текущем вкладе, который является неправильным. />sidebar.component.html
class="nav nav-pills bg-light flex-shrink-0 p-3 position-fixed min-vh-100 rounded">
Protect Accounts
Direct Accounts
Tag Monitors
Users
Scoring Configuration
< /code>
sidebar.component.ts
import { Component, inject } from '@angular/core';
import { NavigationEnd, Router, RouterLink } from '@angular/router';
import { NgbNav, NgbNavItem, NgbNavLink } from '@ng-bootstrap/ng-bootstrap';
import { filter } from 'rxjs';
import { RoutePaths } from '../app.routes';
@Component({
selector: 'app-sidebar',
imports: [NgbNav, NgbNavItem, NgbNavLink, RouterLink],
templateUrl: './sidebar.component.html',
})
export class SidebarComponent {
protected activeId: string | null = null;
protected RoutePaths = RoutePaths;
protected navItems = new Map([
[RoutePaths.ProtectAccounts, [RoutePaths.ProtectAccounts]],
[RoutePaths.DirectAccounts, [RoutePaths.DirectAccounts]],
[RoutePaths.TagMonitors, [RoutePaths.TagMonitors]],
[RoutePaths.Users, [RoutePaths.Users]],
[RoutePaths.ScoringConfig, [RoutePaths.ScoringConfig]],
]);
private router = inject(Router);
constructor() {
this.router.events
.pipe(filter((event) => event instanceof NavigationEnd))
.subscribe((routerEvent) => {
let active = null;
for (const [id, paths] of this.navItems) {
console.log(id);
console.log(paths);
if (paths.find((path) => routerEvent.urlAfterRedirects.startsWith(`/${path}`))) {
active = id;
break;
}
}
this.activeId = active;
});
}
handleLinkClick(event: MouseEvent, path: string) {
if (event.ctrlKey || event.metaKey) {
console.log('clicked', { isCtrl: event.ctrlKey, isMeta: event.metaKey, button: event.button });
const fullUrl = this.router.serializeUrl(this.router.createUrlTree([`/${path}`]));
window.open(fullUrl, '_blank');
// event.preventDefault();
// event.stopPropagation();
// return;
}
}
}
< /code>
Когда я использую Ctrl+Щелкните в боковой панели меню, он должен быть открыт страницу на новой вкладке (которая работает, как и ожидалось), но на текущей вкладке активный стиль (синий фон) был изменен на элемент Ctrl+Clicked Side Menu на текущей активной странице с того места, где мы нажали на CTRL+Click Event. Кто -нибудь может помочь мне исправить это.
Подробнее здесь: https://stackoverflow.com/questions/797 ... debar-item
Ctrl+Щелкнут или в среднем щелкните элемент боковой панели ⇐ CSS
Разбираемся в CSS
-
Anonymous
1753186349
Anonymous
Когда вы CTRL+щелкните или нажмите на средний щелчок элемент боковой панели:
Англуна все еще обновляет [(ActiveId)] через событие Click, запускаемое Ngbnavlink, хотя маршрут не изменился.
Это вызывает синий фон (активный стиль), чтобы применить к Clicked Menu Ittem в текущем вкладе, который является неправильным. />sidebar.component.html
class="nav nav-pills bg-light flex-shrink-0 p-3 position-fixed min-vh-100 rounded">
Protect Accounts
Direct Accounts
Tag Monitors
Users
Scoring Configuration
< /code>
sidebar.component.ts
import { Component, inject } from '@angular/core';
import { NavigationEnd, Router, RouterLink } from '@angular/router';
import { NgbNav, NgbNavItem, NgbNavLink } from '@ng-bootstrap/ng-bootstrap';
import { filter } from 'rxjs';
import { RoutePaths } from '../app.routes';
@Component({
selector: 'app-sidebar',
imports: [NgbNav, NgbNavItem, NgbNavLink, RouterLink],
templateUrl: './sidebar.component.html',
})
export class SidebarComponent {
protected activeId: string | null = null;
protected RoutePaths = RoutePaths;
protected navItems = new Map([
[RoutePaths.ProtectAccounts, [RoutePaths.ProtectAccounts]],
[RoutePaths.DirectAccounts, [RoutePaths.DirectAccounts]],
[RoutePaths.TagMonitors, [RoutePaths.TagMonitors]],
[RoutePaths.Users, [RoutePaths.Users]],
[RoutePaths.ScoringConfig, [RoutePaths.ScoringConfig]],
]);
private router = inject(Router);
constructor() {
this.router.events
.pipe(filter((event) => event instanceof NavigationEnd))
.subscribe((routerEvent) => {
let active = null;
for (const [id, paths] of this.navItems) {
console.log(id);
console.log(paths);
if (paths.find((path) => routerEvent.urlAfterRedirects.startsWith(`/${path}`))) {
active = id;
break;
}
}
this.activeId = active;
});
}
handleLinkClick(event: MouseEvent, path: string) {
if (event.ctrlKey || event.metaKey) {
console.log('clicked', { isCtrl: event.ctrlKey, isMeta: event.metaKey, button: event.button });
const fullUrl = this.router.serializeUrl(this.router.createUrlTree([`/${path}`]));
window.open(fullUrl, '_blank');
// event.preventDefault();
// event.stopPropagation();
// return;
}
}
}
< /code>
Когда я использую Ctrl+Щелкните в боковой панели меню, он должен быть открыт страницу на новой вкладке (которая работает, как и ожидалось), но на текущей вкладке активный стиль (синий фон) был изменен на элемент Ctrl+Clicked Side Menu на текущей активной странице с того места, где мы нажали на CTRL+Click Event. Кто -нибудь может помочь мне исправить это.
Подробнее здесь: [url]https://stackoverflow.com/questions/79710433/ctrlclick-or-middle-click-a-sidebar-item[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия