有没有办法阻止 contentEditable 元素在光标到达底部时滚动?

2024-02-20

例如,我有一个 contentEditable div,我可以在其中输入内容。当文本到达 div 底部时,浏览器会自动滚动 div,以便文本末尾和光标仍然可见。

如何防止 div 滚动,以便输入的文本超出 div 的底部,从而在键入时不再看到光标?

我想要实现的行为就像在 Photoshop 中一样:当您创建一个文本框并输入太多内容时,光标会继续越过框的底部,并且您看不到正在输入的内容。如果展开该框,您将看到所有隐藏的文本。

编辑 2/7/2012 9:27am:这就是我现在所拥有的,但它看起来有点问题,因为滚动位置是在 keyup 事件之后调整的:http://jsfiddle.net/trusktr/hgkak/6/ http://jsfiddle.net/trusktr/hgkak/6/因此,在 keyup 事件之前,光标会暂时置于视图中(对于每次击键)。我希望没有跳跃,并且当有多余的文本而视图没有跳跃时,光标保持在绿色 div 的末尾下方(跳跃对我来说似乎是一个业余黑客:D)


让我们尝试一下 hack:

  • 首先我们尝试阻止或恢复任何滚动
  • 每当用户按下一个键时,我们就会转动该元素的overflow财产给visible避免内容滚动,但同时通过设置其隐藏元素opacity到 0。之后我们立即切换overflow回到hidden并再次显示该元素。
  • 为了避免闪烁,我们创建可编辑元素的克隆(使用overflow: hidden)并显示该元素,同时隐藏原始元素。

我们开始吧(为了方便 DOM 使用 jQuery):

$(function() {

    var editableElement = $('#editable'), clonedElement;

    // Revert any scrolling                    
    editableElement.on("scroll", function(event) {
        editableElement.scrollTop(0);

        // Try to prevent scrolling completely (doesn't seem to work)
        event.preventDefault();
        return false;
    });

    // Switch overflow visibility on and off again on each keystroke.
    // To avoid flickering, a cloned element is positioned below the input area
    // and switched on while we hide the overflowing element.
    editableElement.on("keydown", function() {

        // Create a cloned input element below the original one
        if (!clonedElement) {
            var zIndex = editableElement.css('zIndex');
            if (isNaN(parseInt(zIndex, 10))) {
                zIndex = 10;
                editableElement.css({zIndex: zIndex});
            }    

            clonedElement = editableElement.clone();
            clonedElement.css({
                zIndex: zIndex-1,
                position: 'absolute',
                top: editableElement.offset().top,
                left: editableElement.offset().left,
                overflow: 'hidden',
                // Set pseudo focus highlighting for webkit
                // (needs to be adapted for other browsers)
                outline: 'auto 5px -webkit-focus-ring-color'
            });
            editableElement.before(clonedElement);
        } else {
            // Update contents of the cloned element from the original one
            clonedElement.html(editableElement.html());
        }

        // Here comes the hack:
        //   - set overflow visible but hide element via opactity.
        //   - show cloned element in the meantime
        clonedElement.css({opacity: 1});
        editableElement.css({overflow: 'visible', opacity: 0});

        // Immediately turn of overflow and show element again.
        setTimeout(function() {
            editableElement.css({overflow: 'hidden', opacity: 1});
            clonedElement.css({opacity: 0});
        }, 10);

    });
});

Check 这个jsFiddle http://jsfiddle.net/green/GRvgd/来玩上面的代码。

请注意,这可能不是一个完整的解决方案(我只在 Safari、Chrome 和 Firefox 上尝试过),但对于经过测试的浏览器来说,它似乎有效。您可能需要微调和完善您的实现(例如焦点突出显示)。在 jsFiddle 示例中,我还关闭了拼写检查以避免标记闪烁。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

有没有办法阻止 contentEditable 元素在光标到达底部时滚动? 的相关文章

随机推荐

  • cakePHP 重定向 $this->referer() 无法正常工作

    我有一个 TestController 视图文件 并在其中添加了评论表单 我的页面所在页面的 URL 是 www example com test view slug 现在评论表单发布在 URL www example com 上 comm
  • 即使上传了文件,Laravel Input::hasFile('image') 也会返回 false

    我有一个用于图像上传的表单字段 我用 files gt true 打开它 如下所示 Form label image Image Form file image 在我的控制器中 我想检查文件是否已上传并对其执行某些操作 if Input h
  • IDEA的logcat过滤器可以自动识别正在运行的应用程序吗?

    我找不到这个或 IDEA还没有像 Eclipse 很久以前那样实现了智能过滤器 当我看着logcatIDEA 11 中的选项卡 我没有看到它自动识别正在运行的应用程序并将其添加到All Messages 就像 Eclipse 对每个正在运行
  • JAR 文件不从 ext 加载类文件

    我在Linux系统上安装了JDK 1 6 JAVA HOME目录是 usr java jdk1 6 0 07 我在 Eclipse 上构建了 JAVA HOME 的路径 它通过 Eclipse 顺利运行并加载所有第三方 JAR 文件 usr
  • 预先添加文件的某些行

    我想创建一个脚本来注释掉 Mac OS X 主机文件中包含的行 com 还有一个可以扭转它 So this 127 0 0 1 foo com 127 0 0 1 bar com 127 0 0 1 baz 127 0 0 1 qux 会成
  • CouchDB 附件的自定义属性

    我试图在单个 CouchDB 文档中存储多个独立附件 并为每个附件分配任意属性 即描述 有这样做的约定吗 据我所知 我无法将它们插入 attachments直接构造 提前致谢 您无法修改其中的任何内容 attachments直接使用 因为它
  • 更新特定领域模型属性?

    如何仅更新某些领域模型属性 而不是尝试使用一次又一次地保存完整的领域模型copyToRealmOrUpdate public class User extends RealmObject PrimaryKey public String i
  • Python数据结构的内存大小

    如何找到Python数据结构的内存大小 我正在寻找类似的东西 sizeof 1 hello 2 world 如果它能递归地计算每件事 那就太好了 但即使是基本的非递归结果也有帮助 基本上我想了解各种实现选项 例如元组与元组 列表对比类在内存
  • Youtube IFrame API 来源不受信任

    正如标题所示 我正在使用 IFrame API 我一直在遵循指南API参考 https developers google com youtube iframe api reference 它对我有用 但我发现出现了一些警告并希望解决它们
  • 仅使外部白色透明

    我正在使用 imagick 和 php 来修改上传的图像 我想去除图像周围的白色 使其具有透明背景 使用这个 val 65535 15 val intval val 1 divide by 1 means accept full fuzz
  • 如何从oracle表的多个分区中选择数据

    我正在尝试从分区表中的多个分区中选择数据 它适用于单个分区 select from table partition ParititonName 但不能选择多个分区 select from table partitions Part1 par
  • 添加自定义转换类型以进行字符串格式化

    python 中是否有向字符串格式添加额外的转换类型 使用的标准转换类型 基于字符串的格式化是这样的s对于字符串 d我想要做的是添加一个新字符 我可以为其指定一个自定义处理程序 例如 lambda 函数 该处理程序将返回要插入的字符串 例如
  • 在 C# 中将列表设置为只读

    我有这个示例代码 我想要做的是使 Nums 值只能使用 AddNum 方法写入 namespace ConsoleApplication1 public class Person string myName N A int myAge 0
  • ExecutorService 超时但不阻塞主线程

    我想在有时间限制的后台执行一些工作 问题是 我不想阻塞主线程 简单的实现是有两个执行器服务 一个负责安排 超时 第二个负责完成工作 final ExecutorService backgroundExecutor Executors new
  • F# 如何捕获所有异常

    我知道如何捕获特定异常 如下例所示 let test zip archive candidate zip archive let rc try ZipFile Open candidate zip archive ToString ZipA
  • Laravel 5.8 中 Auth::user() 返回 null

    我的 Laravel 5 8 10 项目中遇到身份验证问题 我没有使用 Laravel 创建的默认表单进行身份验证 当我在浏览器中访问 URL 仪表板时 通常用户会在登录时获得重定向 无论如何 应用程序允许它 另外当我使用时Auth use
  • TYPE_E_CANTLOADLIBRARY 仅当在 Windows 2003 x64 上的单独线程上使用 COM 对象时

    我有一个访问 COM 对象的 Windows 窗体应用程序 编译为 x86 它给了我以下错误 only在 Windows 2003 x64 上 当代码在单独的线程上运行时 创建 IDoc 期间出现异常 无法将类型 PTISG COM Tek
  • 修复 ARC 中潜在的内存泄漏

    以下单例类 SharedManager 辅助方法可能会导致保留周期 在静态分析器中收到警告 在行分配的对象的潜在泄漏 我该如何修复 我确实尝试使 ivar uuid weak 但在分析时仍然出现警告 NSString weak uuid b
  • std::numeric_limits::epsilon() 可以用来做什么?

    unsigned int updateStandardStopping unsigned int numInliers unsigned int totPoints unsigned int sampleSize double max hy
  • 有没有办法阻止 contentEditable 元素在光标到达底部时滚动?

    例如 我有一个 contentEditable div 我可以在其中输入内容 当文本到达 div 底部时 浏览器会自动滚动 div 以便文本末尾和光标仍然可见 如何防止 div 滚动 以便输入的文本超出 div 的底部 从而在键入时不再看到