- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
最近我的 chrome 版本越来越频繁地做一些奇怪的事情(ubuntu 18.04 上的 74.0.3729.131)。我有一个小的编辑器脚本,它有一个显示代码的 textarea。 textarea 具有固定大小和垂直滚动条。除此之外没有什么花哨的。
通常,当我插入换行符(textarea 的正常行为)时,滚动条不会移动。现在出于某种原因,大约 80% 的时间它会向下滚动 textarea 直到插入符号的位置位于 textarea 的顶部。奇怪的是,如果我删除并在同一位置输入换行符,它通常不会滚动。
我不确定这是否是 Chrome 中的一些新问题。我以前使用相同编辑器的版本没有这个问题。
这是一个演示问题的代码笔,滚动到某行,按回车键,textarea 应该向下滚动。尝试几次以查看不可预测的行为(添加代码只是为了能够添加链接,因为您可以看到它只是一个文本区域)。
https://codepen.io/anon/pen/rgKqMb
<textarea style="width:90%;height:300px"></textarea>
最佳答案
快到2020年底了,Chrome 86版本还存在这个问题?更重要的是,我很惊讶我没有找到关于这个问题的更多信息(投诉)(这篇文章是我发现的唯一一篇专门谈到这个问题的文章。)我观察到这种行为不仅发生在打字中,而且粘贴任何包含换行符的文本。我还观察到,如果我在发生这种情况后执行撤消操作,则会发生另一个随机滚动,使我在页面上更远,并且离插入符号的位置不远。
我对这种行为进行了长时间的试验和检查,但找不到任何可重复的情况,这可能会提供有关如何预测何时会发生的线索。它真的只是看起来“随机”。尽管如此,我不得不为我正在创建的 NWJS 编辑器应用程序解决这个问题(NWJS 使用 Chrome 作为 UI。)
这似乎对我有用:
首先,让我从简单开始介绍原理。我们将“输入”监听器和“滚动”监听器附加到文本区域。这是有效的,因为根据我的观察,“输入”[1] 监听器在随机滚动 Action 发生之前被触发。
滚动监听器记录每个滚动操作并将其保存在全局 prevScrollPos
中。 .它还检查全局标志 scrollCorrection
.
“输入”监听器设置 scrollCorrection
每次将文本输入到 textarea 时标记。请记住,这发生在随机滚动发生之前。
所以下一次滚动发生,这可能是令人讨厌的随机 Action ,滚动监听器将清除 scrollCorrection
,然后将 textarea 滚动到上一个滚动位置,即,将其滚动回“随机”滚动之前的位置。但问题是不可预测的,如果没有随机滚动并且下一次滚动是有意的怎么办?这没什么大不了的。这只是意味着如果用户手动滚动,第一个滚动事件基本上无效,但之后(清除 scrollCorrection
)一切都会正常滚动。由于在正常滚动期间,事件会如此迅速地吐出,因此不太可能有任何明显的影响。
这是代码:
let textarea;
let prevScrollPos = 0;
let scrollCorrection = false;
function onScroll(evt) {
if (scrollCorrection) {
// Reset this right off so it doesn't get retriggered by the corrction.
scrollCorrection = false;
textarea.scrollTop = prevScrollPos;
}
prevScrollPos = textarea.scrollTop;
}
function onInput(evt) {
scrollCorrection = true;
}
window.addEventListener("load", () => {
textarea = document.getElementById("example_textarea");
textarea.addEventListener("scroll", onScroll);
textarea.addEventListener("input", onInput);
})
现在让我们扩展它:
getBoundingClientRect
在生成的包含块等上。在我的情况下,我已经为我的编辑做了大部分工作,所以这不是什么额外的费用。但是我已经包含了一些伪代码来展示如何在滚动校正机制中实现这一点。
setCaretCorrection
基本上执行上面的步骤 1 - 7。
let textarea;
let prevScrollPos = 0;
let scrollCorrection = false;
let caretCorrection = 0;
function onScroll(evt) {
if (scrollCorrection) {
// Reset this right off so it doesn't get retriggered by the correction.
scrollCorrection = false;
textarea.scrollTop = prevScrollPos + caretCorrection;
caretCorrection = 0;
}
prevScrollPos = textarea.scrollTop;
}
function onTextareaInput() {
scrollCorrection = true;
setCaretCorrection();
}
function setCaretCorrection(evt) {
let caretPos = textarea.selectionStart;
let scrollingNeeded;
let amountToScroll;
/* ... Some code to determine xy position of caret relative to
textarea viewport, if it is scrolled out of view, and if
so, how much to scroll to bring it in view. ... */
if (scrollingNeeded) {
if (scrollCorrection) {
// scrollCorrection is true meaning random scroll has not occurred yet,
// so flag the scroll listener to add additional correction. This method
// won't cause a flicker which could happen if we scrollBy() explicitly.
caretCorrection = amountToScroll;
} else {
// Random scroll has already occurred and been corrected, so we are
// forced to do the additional "out of viewport" correction explicitly.
// Note, in my situation I never saw this condition happen.
textarea.scrollBy(0, amountToScroll);
}
}
}
可以更进一步,使用实验事件“beforeinput”[3] 来优化这一点,从而减少对
setCaretCorrection
的不必要调用。制作。如果检查
event.data
来自“beforeinput”事件,在某些情况下它会报告要输入的数据。如果没有,则输出
null
.不幸的是,当输入换行符时,
event.data
是
null
.但是,如果它们被粘贴,它会报告换行符。所以至少可以看到 event.data 是否包含字符串,如果字符串不包含换行符,则跳过整个更正操作。 (另外,请参见下面的 [1]。)
scrollCorrection
在随机滚动发生之前。尽管请注意“beforeinput”是实验性的。
关于javascript - 添加换行符后防止 chrome 中的 textarea 滚动行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56329625/
非常简单的问题 - 是否可以通过 Chromium 创建 google chrome 扩展,并让在不同操作系统上运行 Chrome 的人使用相同的扩展? 我正在Ubuntu上开发。 最佳答案 是的,完
我了解 chrome.bookmarks API(记录在 http://goo.gl/tIb6V6 )旨在用于开发访问/操作我的 Chrome 书签的 Chrome 扩展程序(当然要在 Chrome
在比较开源浏览器 Firefox 和 Chromium 的扩展、附加组件和列表时,我试图找到一些有趣的数据。 我感兴趣的是多宿主扩展(两个浏览器列表上都可用的扩展)。 但是当浏览 Chromium 扩
使用新的 chrome.notifications API,我无法从我的扩展程序中获取通知以显示。即使是最基本的通知也无法为我显示,但我没有收到任何错误,并且回调函数已正确执行。 list .json
我正在构建一个在 Chrome 上运行的信息亭媒体,可以播放带音频的视频。我知道默认情况下,chrome 只允许自动播放带有静音 Prop 的视频。 而且我知道我可以通过 chrome://flags
我从来没有真正写过 真实 Chrome 扩展程序。不久前我做了一个只是一个链接下拉列表,但这并不重要。无论如何,与其先回到关于编写 Chrome 扩展程序的大量教程中,不如先确保我的想法是可行的。 我
主要目的是在单个容器中运行多个 chrome 浏览器(9 个浏览器)。 我有一个集线器和节点设置,其中包含多个浏览器的容器,可在单个 chrome 节点容器中运行。我使用以下 docker 命令创建了
我想写一个小的 chrome 扩展程序,它应该从网页 A(当前网页)获取信息,将选项卡更新到网页 B,然后将代码注入(inject)网页 B。不幸的是,以下代码正在将网页更新到 B 但注入(injec
是否可以打开 Chrome 开发者工具来检查 Chrome 应用? 最佳答案 所有可调试目标都列在 chrome://inspect/ 下。请参阅“应用程序”标签。 关于google-chrome -
我正在为 Google Chrome 开发一个应用程序,我想知道如何收费。 问题是我住在巴西,在这个链接上它告诉我它不支持 Chrome 网上应用店付款。如果没有 Chrome 网上商店付款,我可以通
我刚刚更新到 Chrome 32.0.1700.76 m(在 Win7 上)并且开发人员工具已更改。 特别令人痛苦的是用于检查页面元素的放大镜图标消失了。也没有提到它的快捷方式列表。 任何人都知道这已
我在 chrome-extension API (chrome.webrequest) 中遇到问题。 我的 list .json { "name": "tesst", "version": "
我已经制作了 chrome 主机来在我的扩展程序和我的进程之间传递 native 消息,我的进程在 chrome 启动时启动,但在我关闭 chrome 时不关闭,我应该向主机的 list 添加参数还是
文档对此非常不清楚。我知道如果您自己托管您的扩展程序,您可以通过增加版本号来自动更新您的扩展程序。但是,我不知道您是否可以在仍发布到 chrome 网上商店的同时进行自托管。 我不敢相信 Google
我最近一直在使用 Selenium WebDriver。我还专门与 chromedriver 合作。每当我打开一个新的 chrome 窗口 (driver.get(url)) 时,Chrome 都会以
我指的是chrome://flags 我很想知道是否可以通过自定义 chrome 扩展启用或禁用特定的 chrome 标志? 例如-我想启用 Enable Media Source API on e
当我在 chrome 开发者仪表板上向我的扩展程序上传更新时, 它无法这样做,它显示, An error occurred: Failed to process your item. Chrome W
我正在尝试编写一个需要用户身份验证的 chrome 扩展。 Google's tutorial建议我需要先上传到网上商店才能获得 key : Login to the Google APIs Cons
我已经开发了一个 Chrome 扩展程序并且我已经打包了它。 我将我的扩展程序发送给一些人试用,但 Chrome 开始阻止它在商店中找不到的扩展程序。 有没有办法安装我的扩展程序而不会被 Chrome
某些 Chrome 扩展不适用于 Chromium。例如:http://code.google.com/chrome/extensions/samples.html#5d81304a17cf7ac28
我是一名优秀的程序员,十分优秀!