- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我有一个 javascript 下拉菜单,它可以工作,但是当我将菜单 HTML 放入 Dart 组件模板中时,菜单就不再工作了。我猜这是因为 Javascript 无法再访问这些 DOM 元素。
这是人们普遍遇到的问题吗?有什么解决办法吗?
我的全局 JavaScript 是:
$('body')
.on('mouseenter', '.navbar.main [data-toggle="dropdown"]', function()
{
if (!$(this).parent('.dropdown').is('.open'))
$(this).click();
});
else {
$('[data-toggle="dropdown"]').dropdown();
}
$('.navbar.main')
.on('mouseleave', function(){
$(this).find('.dropdown.open').find('> [data-toggle="dropdown"]').click();
});
<小时/>
所以,最后我在组件中用 Dart 重写了这个 Javascript:
import 'package:angular/angular.dart';
import 'dart:html' show querySelector;
import 'dart:html';
@Component(
applyAuthorStyles:true,
publishAs: 'cmp',
selector: 'menu',
templateUrl: '../lib/components/menu.html')
class MenuComponent extends AttachAware with ShadowRootAware {
MenuComponent(Scope scope) {
}
void attach() {
}
void closeAllOpenMenus(ShadowRoot shadowRoot) {
shadowRoot.querySelectorAll('.dropdown').classes.remove("open");
}
void onShadowRoot(ShadowRoot shadowRoot) {
shadowRoot.querySelectorAll('.dropdown-toggle').onMouseEnter.listen((event) {
closeAllOpenMenus(shadowRoot);
Element element = event.target.parent;
element.classes.add("open");
});
shadowRoot.querySelectorAll('.navbar').onMouseLeave.listen((event) {
closeAllOpenMenus(shadowRoot);
});
}
最佳答案
这是 ShadowDOM 的常见问题。
据我所知jQuery仍然不支持shadowDOM。
.on('mouseenter', '.navbar.main [data-toggle="dropdown"]', function()
此代码不会在组件内找到具有 data-toggle="dropdown"
属性的元素,因此不会应用下拉功能。
这也适用于 Bootstrap 选择器在组件内找不到元素的 CSS。解决方法是在组件内添加或链接 CSS。
这并不能解决选择器的祖先(.ancestor .descendant { color: #fff; }
在组件外部而后代在组件内部的情况,因为此类选择器不会跨影子 DOM边界。
关于Javascript 下拉菜单在 Dart 模板中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23165546/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!