- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在下面的代码片段中,我必须使用 div
。当我尝试滚动其中任何一个时,我想同步它们的位置。当第二个 div 滚动时,我正在更改第一个 div 的 transform
并且它起作用了。但是第一个 div 永远不会滚动。我尝试将 mousewheel
事件传递给第二个事件,但没有成功。
而且我无法使 section
可滚动 - 这只是一个简化的示例。
// This code works
// `.labels` moves together with scroll of `.scrollable`
document.querySelector(".scrollable").addEventListener('scroll', function (e) {
var dy = this.scrollTop;
document.querySelector(".labels").style.transform = "translateY(" + -dy + "px)";
});
// This code does NOT work
// I want `.scrollable` to be scrolled when I try to scroll `.labels`
document.querySelector(".labels").addEventListener('wheel', function (e) {
console.log(Date.now());
document.querySelector(".scrollable").dispatchEvent(new MouseEvent(e.type, e));
});
section {
border: 1px solid red;
line-height: 2em;
height: 8em;
display: inline-block;
overflow: hidden;
white-space: nowrap;
}
div {
display: inline-block;
vertical-align: top;
padding: 0 .25em;
}
.scrollable {
max-height: 100%;
overflow: auto;
}
.labels {
background: silver;
}
.as-console-wrapper.as-console-wrapper {
max-height: 70px;
}
<section>
<div class="labels">
Label 1<br>
Label 2<br>
Label 3<br>
Label 4<br>
Label 5<br>
Label 6<br>
Label 7<br>
</div><div class="scrollable">
Line 1<br>
Line 2<br>
Line 3<br>
Line 4<br>
Line 5<br>
Line 6<br>
Line 7<br>
</div>
</section>
最佳答案
[编辑]如果您打算在 Firefox 上使用 mousewheel
事件,请考虑阅读其他 SO 问题:mousewheel event is not triggering in firefox browser
[编辑 2]对代码片段的新编辑,检查上面的注释以了解上下文。
CSS 有一个问题,您需要 labels
元素可滚动,并且要同步两个元素之间的滚动,您可以简单地使用 scrollTop
。
我已经修改了你的示例以使其工作:
var scrollableEl = document.querySelector(".scrollable");
var labelsEl = document.querySelector(".labels");
scrollableEl.addEventListener('scroll', function (e) {
labelsEl.style.transform = `translateY(${ -scrollableEl.scrollTop }px)`;
e.preventDefault();
});
labelsEl.addEventListener('wheel', function (e) {
scrollableEl.scrollTop += (e.deltaY / 2);
e.preventDefault();
});
section {
border: 1px solid red;
line-height: 2em;
height: 8em;
display: inline-block;
overflow: hidden;
white-space: nowrap;
}
div {
display: inline-block;
vertical-align: top;
padding: 0 .25em;
}
.scrollable {
max-height: 100%;
overflow: auto;
}
.labels {
background: silver;
}
.as-console-wrapper.as-console-wrapper {
max-height: 70px;
}
<section>
<div class="labels">
Label 1<br>
Label 2<br>
Label 3<br>
Label 4<br>
Label 5<br>
Label 6<br>
Label 7<br>
</div><div class="scrollable">
Line 1<br>
Line 2<br>
Line 3<br>
Line 4<br>
Line 5<br>
Line 6<br>
Line 7<br>
</div>
</section>
我已经创建了一个新类来重用 css,所以期望 javascript 查询选择器从 .scrollable--pane
类中获取元素。
关于javascript - 强制其他 div 在我的 `wheel` 上滚动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47516917/
我一直很难编辑我的 .htaccess 文件来一起做这三件事。我已经能够分别获得每个部分,但我只是不明白逻辑流程如何使它们全部工作。 这是我能够使用 bluehost support 上的演示进行整合
我制作的宏将模板工作簿保存为两个单独的文件。每个测试保存一个(位置 1、2、3 或 4),然后在另一个宏中使用每个测试的数据。第二个是保留用于备份的原始数据文件。现在的问题是每次我在每个位置运行测试并
我正在写一篇关于如何使用 OCaml 的模块系统而不是 Java 的 OO 系统(一个有趣的视角)的博客文章。我遇到了一些我不理解的关于强制的事情。下面是一个基本模块和两个包含它的模块: module
我有一段将被执行多次(5,000+)的代码,以及一个仅在第一次为真的 if 语句。我曾想过使用“FIRST”变量并每次都进行比较,但每次都检查它似乎是一种浪费,即使我知道它不需要。 bool FIRS
首先,我是 Perforce 的新手,我主要通过其文档进行学习。 因此,我们即将从 CVS 迁移到 Perforce,我最近学到了一个避免更改每个工作区的 P4CLIENT 的好方法,即在工作区根目录
我正在为一段代码编写测试,其中包含我试图涵盖的 IOException 捕获。 try/catch 看起来像这样: try { oos = new ObjectOutputStream(new
我正在尝试在新闻项目滚动之间添加延迟。我知道 $.each() 通过不等待动画完成来完成其工作,但我想知道如何制作它,以便一次向上滚动一个项目并等到最后一个动画完成后再继续在循环中。 $(functi
假设已经编写了一个方法,需要一个排序列表作为其输入之一。当然这将在代码中进行注释和记录,param 将被命名为“sortedList”,但如果有人忘记,则会出现错误。 有没有办法强制输入必须排序?我正
我正在尝试将传入请求重定向到 https://www.domain.com/和所有 https://www.domain.com/ {所有页面}并且没有什么麻烦。我试过的方法: 添加此行:Redire
我将如何实现以下内容: title_selection = raw_input("Please type in the number of your title and press Enter.\n%
我有一个登录表单,我需要强制关闭自动完成功能。我试过了 jquery: $('#login').attr("autocomplete", "off"); HTML: Javascript:docume
我想知道我应该怎么做才能强制从 dev 分支 merge 到我的 master 分支?使用“git merge dev”会导致很多冲突。但是,我不想单独处理它们。相反,我只是想使用我的 dev 分支中
当安装 Hl7.Fhir.DSTU2 和 Hl7.Fhir.R4 这两个 Nuget 包时,我们得到如下信息: DSTU2 包似乎在使用 Hl7.Fhir.Support.Poco 版本 3.4.0
我正在尝试让一个功能组件在 testFn 执行时强制重新渲染。我想使用状态来做到这一点(如果有更好的方法请说出来),这似乎成功地强制重新渲染但只有两次,然后什么都没有。 我构建了一个简单的演示来模拟这
默认情况下,g++ 似乎会省略未使用的类内定义方法的代码。示例 from my previous question : struct Foo { void bar() {} void baz(
我正在尝试使用 here 中介绍的技术使我的网站背景以比内容慢的速度滚动。我不希望背景固定,只希望更慢。 这是 HTML 的样子: .parallax { perspective: 1px;
我能找到的最相似的问题是 'how to create a row of scrollable text boxes or widgets in flutter inside a ListView?'
我有以下 eslint 配置: "object-curly-newline": ["error", { "ImportDeclaration": "never",
我正在使用 TinyMCE 插件并将 valid_elements 选项设置为: "a[href|target:_blank],strong/b,em/i,br,p,ul,ol,li" 即使没有列出数
您好,我想使用以下命令放置多行描述 p4 --field Description="MY CLN Header \\n my CLN complete description in two -thre
我是一名优秀的程序员,十分优秀!