一种输入标题导致运行时错误的情况

问题表现就是输入标题之后回车下一行也是标题,之后报运行时错误,直接贴操作过程了

  1. 首先在编辑器中正常输入(本次复现条件是输入列表)

  2. 输入列表,之后通过回车返回到段落块

  3. 输入 #Ctrl+Alt+1建立标题

    PixPin20250324092425.png

  4. 输入文本。注意到此时大纲列表中并不正常刷新当前标题文本

    PixPin20250324092446.png

  5. 按下删除键会直接删除当前整个标题,重建标题仍然报错

  6. 重建索引有概率解决问题,不过我在未报运行时错误时重建索引之后仍然出现问题

  7. 如果输入标题后出现当前问题:

    1. 已经输入回车出现第二个标题块,则只能删除整个标题块
    2. 未输入回车,光标仍在当前标题块
      1. 通过Ctrl+Alt+0可以转换回段落块

      2. 通过Ctrl+Alt+1可以转换回标题块

      3. 此时标题块文本右侧可能出现 <protyle-html> 标签,也可能没有

        PixPin20250324092523.png

      4. 不过此时大纲中显示当前标题名称,可以正常继续输入不会触发运行时错误

本次复现条件是主题,默认主题下没有测试,不过不容易观察也不容易复现,暂且认为是使用第三方主题都能复现。复现并不局限于单个文档,也不局限于某个主题 ,甚至不局限于输入法

  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    25518 引用 • 105538 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • EmptyLight 2 评论

    我自己的主题因为不知道什么修改暂时无法复现(希望以后也不要复现了),目前暂时切换到 Savor 录制问题。

    在浏览器伺服可以复现问题。复现的录屏附在下方。(含 getSelection()

    因链滴限制还是放网盘了

    还是无法重现,range 也是正常的,换个输入发试试,或者输入数字再试试。
    Vanessa
    @Vanessa 感谢 V 大指点,最新测试中发现问题限制到小狼毫输入法复现了,之前微软拼音也会的,今天测试不出来了,我准备检查一下触发情况,去那边反馈问问
    EmptyLight 1
  • 其他回帖
  • 我这里实在重现不了,你从新建工作空间开始录屏看看

    1 回复
  • EmptyLight

    siyuan-vscodelite-edit/src/block/title-icon.scss at scss · emptylight370/siyuan-vscodelite-edit 编译得到,图标为单独 svg,这里由于长度限制只取一到三级标题

    @charset "UTF-8";
    /* 用于修复显示图标之后标题会显示在下一行的问题 */
    [data-node-id].h1 div:nth-child(1),
    .protyle-preview h1 div:nth-child(1) {
      display: inline-block;
      word-wrap: break-word;
      overflow-wrap: break-word;
    }
    
    [data-node-id].h2 div:nth-child(1),
    .protyle-preview h2 div:nth-child(1) {
      display: inline-block;
      word-wrap: break-word;
      overflow-wrap: break-word;
    }
    
    [data-node-id].h3 div:nth-child(1),
    .protyle-preview h3 div:nth-child(1) {
      display: inline-block;
      word-wrap: break-word;
      overflow-wrap: break-word;
    }
    
    /* h1标签基本样式 */
    [data-node-id].h1[fold="1"][data-type=NodeHeading]::before,
    .protyle-preview h1[fold="1"]::before, [data-node-id].h1::before,
    .protyle-preview h1::before {
      content: "";
      display: inline-block;
      position: relative;
      width: 1.75rem;
      height: 1.75rem;
      mask: url(../../resources/h1.svg) no-repeat center center;
      mask-size: contain;
      background-color: var(--mk-block-header-h1);
      top: 0.2rem;
      margin-right: 0.2rem;
    }
    
    /* h1标签 */
    [data-node-id].h1[fold="1"][data-type=NodeHeading]::before,
    .protyle-preview h1[fold="1"]::before {
      height: 1.75rem !important;
      border-radius: unset;
      margin-top: unset;
      left: unset !important;
      top: 0.2rem !important;
    }
    
    /* h2标签基本样式 */
    [data-node-id].h2[fold="1"][data-type=NodeHeading]::before,
    .protyle-preview h2[fold="1"]::before, [data-node-id].h2::before,
    .protyle-preview h2::before {
      content: "";
      display: inline-block;
      position: relative;
      width: 1.55rem;
      height: 1.55rem;
      mask: url(../../resources/h2.svg) no-repeat center center;
      mask-size: contain;
      background-color: var(--mk-block-header-h2);
      top: 0.2rem;
      margin-right: 0.2rem;
    }
    
    /* h2标签 */
    [data-node-id].h2[fold="1"][data-type=NodeHeading]::before,
    .protyle-preview h2[fold="1"]::before {
      height: 1.55rem !important;
      border-radius: unset;
      margin-top: unset;
      left: unset !important;
      top: 0.2rem !important;
    }
    
    /* h3标签基本样式 */
    [data-node-id].h3[fold="1"][data-type=NodeHeading]::before,
    .protyle-preview h3[fold="1"]::before, [data-node-id].h3::before,
    .protyle-preview h3::before {
      content: "";
      display: inline-block;
      position: relative;
      width: 1.38rem;
      height: 1.38rem;
      mask: url(../../resources/h3.svg) no-repeat center center;
      mask-size: contain;
      background-color: var(--mk-block-header-h3);
      top: 0.2rem;
      margin-right: 0.2rem;
    }
    
    /* h3标签 */
    [data-node-id].h3[fold="1"][data-type=NodeHeading]::before,
    .protyle-preview h3[fold="1"]::before {
      height: 1.38rem !important;
      border-radius: unset;
      margin-top: unset;
      left: unset !important;
      top: 0.2rem !important;
    }
    
    /*# sourceMappingURL=title-icon.css.map */
    
  • EmptyLight

    目前复现情况:

    • VSCode Lite Edit 主题在启用标题图标开关后可复现
    • Savor 主题可复现,但此时出问题的标题后未显示当前标题级别的那些点

    预计问题是主题修改主题样式导致的,对于 VSCode Lite Edit 主题是 ::before,Savor 未知,不是 ::before::after,但是可以复现问题,并且在出现问题时不显示标题后的点

    2 回复
  • 查看全部回帖

推荐标签 标签

  • GAE

    Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

    14 引用 • 42 回帖 • 815 关注
  • Hexo

    Hexo 是一款快速、简洁且高效的博客框架,使用 Node.js 编写。

    22 引用 • 148 回帖 • 17 关注
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖
  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    199 引用 • 543 回帖
  • Oracle

    Oracle(甲骨文)公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。1989 年正式进入中国市场。2013 年,甲骨文已超越 IBM,成为继 Microsoft 后全球第二大软件公司。

    107 引用 • 127 回帖 • 336 关注
  • 996
    13 引用 • 200 回帖 • 8 关注
  • 机器学习

    机器学习(Machine Learning)是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。

    83 引用 • 37 回帖
  • Office

    Office 现已更名为 Microsoft 365. Microsoft 365 将高级 Office 应用(如 Word、Excel 和 PowerPoint)与 1 TB 的 OneDrive 云存储空间、高级安全性等结合在一起,可帮助你在任何设备上完成操作。

    5 引用 • 34 回帖
  • Mobi.css

    Mobi.css is a lightweight, flexible CSS framework that focus on mobile.

    1 引用 • 6 回帖 • 760 关注
  • Postman

    Postman 是一款简单好用的 HTTP API 调试工具。

    4 引用 • 3 回帖
  • PostgreSQL

    PostgreSQL 是一款功能强大的企业级数据库系统,在 BSD 开源许可证下发布。

    22 引用 • 22 回帖 • 2 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖 • 3 关注
  • iOS

    iOS 是由苹果公司开发的移动操作系统,最早于 2007 年 1 月 9 日的 Macworld 大会上公布这个系统,最初是设计给 iPhone 使用的,后来陆续套用到 iPod touch、iPad 以及 Apple TV 等产品上。iOS 与苹果的 Mac OS X 操作系统一样,属于类 Unix 的商业操作系统。

    89 引用 • 150 回帖 • 1 关注
  • WordPress

    WordPress 是一个使用 PHP 语言开发的博客平台,用户可以在支持 PHP 和 MySQL 数据库的服务器上架设自己的博客。也可以把 WordPress 当作一个内容管理系统(CMS)来使用。WordPress 是一个免费的开源项目,在 GNU 通用公共许可证(GPLv2)下授权发布。

    67 引用 • 114 回帖 • 193 关注
  • RabbitMQ

    RabbitMQ 是一个开源的 AMQP 实现,服务器端用 Erlang 语言编写,支持多种语言客户端,如:Python、Ruby、.NET、Java、C、PHP、ActionScript 等。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。

    49 引用 • 60 回帖 • 344 关注
  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    52 引用 • 190 回帖
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖 • 1 关注
  • 域名

    域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。

    43 引用 • 208 回帖
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    5 引用 • 7 回帖 • 2 关注
  • Unity

    Unity 是由 Unity Technologies 开发的一个让开发者可以轻松创建诸如 2D、3D 多平台的综合型游戏开发工具,是一个全面整合的专业游戏引擎。

    25 引用 • 7 回帖 • 122 关注
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖
  • Netty

    Netty 是一个基于 NIO 的客户端-服务器编程框架,使用 Netty 可以让你快速、简单地开发出一个可维护、高性能的网络应用,例如实现了某种协议的客户、服务端应用。

    49 引用 • 33 回帖 • 38 关注
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    15 引用 • 7 回帖 • 2 关注
  • CAP

    CAP 指的是在一个分布式系统中, Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可兼得。

    12 引用 • 5 回帖 • 631 关注
  • 人工智能

    人工智能(Artificial Intelligence)是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门技术科学。

    170 引用 • 315 回帖
  • 大疆创新

    深圳市大疆创新科技有限公司(DJI-Innovations,简称 DJI),成立于 2006 年,是全球领先的无人飞行器控制系统及无人机解决方案的研发和生产商,客户遍布全球 100 多个国家。通过持续的创新,大疆致力于为无人机工业、行业用户以及专业航拍应用提供性能最强、体验最佳的革命性智能飞控产品和解决方案。

    2 引用 • 14 回帖 • 4 关注
  • Telegram

    Telegram 是一个非盈利性、基于云端的即时消息服务。它提供了支持各大操作系统平台的开源的客户端,也提供了很多强大的 APIs 给开发者创建自己的客户端和机器人。

    5 引用 • 35 回帖