开发者能不能把双链功能赋予给代码块中的代码啊?这个功能非常有用!

本贴最后更新于 288 天前,其中的信息可能已经事过境迁

我是思源粉丝一枚,目前支持段落文本的双链功能,但是我发现在代码块里面无法使用双链功能,这极大限制了思源阅读代码解析代码的能力,所以能不能将双链预览功能扩展到代码块中去,这样代码的注释就能注释一次,全文件都能预览了!另外我感觉(小白的感觉,勿喷)代码块的文本就像段落块里面的文本一样可以添加双链功能,不会有太多技术上的难度,希望开发者考虑!!!非常感谢!!!

  • 思源笔记

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

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

    18826 引用 • 70472 回帖 • 1 关注

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • 88250

    抱歉,这个支持不了。

    1 回复
  • 很有意思的想法,但是如果你一行注释都解释不明白,还需要添加双链预览。是不是应该想一想,这代码本身是不是有点问题。

    1 回复
  • SiYuan005

    我们的出发点是加快代码解析的速度,而不是靠脑子记住语句或变量在第一次注释时的意义,解放人脑而不是质疑代码本身的问题。

  • SiYuan005

    请问为什么不能支持啊?技术比较难吗?

    2 回复
  • SiYuan005

    对于大型软件工程来说,这个双链预览功能极其有用!

    有相同需求的小伙伴可以留言啊!

    我觉得这是个创业的好点子,完全可以开发出一款代码阅读的思源子类软件!到时候就像 github 一样的产品,哈哈哈哈哈!

  • 88250

    嗯,技术上难以实现,你有具体实现思路的话发出来我们讨论看看。

    4 回复
  • SiYuan005

    架构方面:代码块分为两个属性,一个属性是渲染属性,另外一个就是文本属性,两个分开就可以了。对于文本属性,已有的双链预览功能迁移即可,只要保证渲染属性不干扰就行了;渲染属性主要是为了代码的可读性。细节方面:每一行代码及其注释可作为一个段落块来看待。

    1 回复
  • 代码块中的注释是 <span class="hljs-comment">/* foo */</span> 这种, 可以在加载时或鼠标悬浮时将注释中 siyuan://xxx 样式的字符串转换为链接, 这样就能实现单向的引用与鼠标悬浮预览了

    更进一步, 可以将注释中非注释符号的内容全部当做 markdown 渲染, 这样更加方便实现

    2 回复
  • jssolo

    代码如果加双链的话,我认为会打乱代码本身的存储逻辑,可能会导致一些未知的问题

    1 回复
  • 88250

    整个插件试试 😉

    1 回复
  • 88250

    按照这个思路恐怕实现不了,你有空的话可以看下思源相关代码。

    1 回复
  • SiYuan005

    好的,谢谢!

  • 正在给 monaco-editor 插件塞这个功能huaji

  • SiYuan005

    代码即文本,没有什么存储逻辑吧?

  • SiYuan005

    要的就是悬浮预览!可以说是最好功能了!

  • 代码还要双链,那不就成了 IDE 里的引用和被引用查询了么?使用的人难道还要把代码仓库甚至三方源码放到思源里管理么,过了吧…………

    这种功能我觉得云 IDE 更适合一些

    1 回复
  • duyujie

    代码块其实应该命名为纯文本块,核心逻辑是里面的任何字符保持原样,不被解析为 markdown。如果支持了双链就违背这个逻辑了。。。

  • 双链只能在有 ID 的块和块之间建立,如果要给代码行增加双链,就意味着要把代码行都变成块,这个更改就太大了。

    1 回复
  • yss930819

    请问这个需求没太理解。为什么不用 IDE 去看代码而是用思源笔记去看代码?是想代码和文档一起对照码?

    1 回复
  • SiYuan005

    IDE 无法预览文档中的相同名字的变量(比如第一次注释的代码行总是希望处处能够鼠标悬浮预览),总是需要鼠标滑上滑下,跳来跳去,打断了阅读代码的思维意识流。

  • SiYuan005

    可以做成另外一个单独的产品,叫思源 IDE,哈哈哈哈哈

  • SiYuan005

    推荐一款可以鼠标悬浮预览 引用和被引用的 IDE 也可以的!

    2 回复
  • vscode 可以的

    1 回复
  • 那可以把[代码块]变成 [段落块]么,不过这个段落块的颜色和代码块的文字颜色是一样的.这样就能起到代码块的视觉效果和普通块的编辑效果

  • SiYuan005

    需要安装插件吗?大佬讲详细点呀!谢谢

  • iamqiz 6 评论

    @88250 @Vanessa

    楼主的这个提议和我之前的提议(让代码块支持修改文本样式,有 10 比 3 的支持率)本质上差不多, 我觉得把这个提议解决之后,楼主的这个提议也就容易解决了;

    [提议] 代码块支持加粗 | 改颜色等文本样式 - 链滴
    [提议] 代码块支持加粗 | 改颜色等文本样式

    @shuoying 萌佬的方案是利用代码块对应语言的注释语法来实现,

    但我倾向于在不增加额外注释语句的情况下进行注释,

    原地加注释的效果图如下:

    Snipaste 环境返回 20230722113436.png

    目前代码块的高亮解析使用的第三方,代码块不高亮还好,如果需要高亮和引用的话工作量无上限呀。
    Vanessa
    @Vanessa 我看第三方文档了,可以让其忽略特定的 css 元素,让它忽略用户生成的高亮和引用 这样就解决了吧. 核心 API —highlight.js 11.8.0 文档 https://highlightjs.readthedocs.io/en/latest/api.html#configure
    iamqiz
    @iamqiz 这个先记录一下吧,解析也需要修改。感觉作用不大,工作量巨大 😄
    Vanessa
    @Vanessa 我觉得作用大,之前提议 [提议] 代码块支持加粗 | 改颜色等文本样式 10 人支持 3 人反对; 先放着以后再说
    iamqiz
    @iamqiz Issue #8820 · siyuan-note/siyuan 那我还是建一个 issue 吧
    Vanessa
    @Vanessa 因为 Markdown 没有这样的语法,要做的话估计只能通过自定义块了,代码块上无法实现。
    88250
  • yss930819

    是想这样看吗?下面的预览框里甚至能改。不过悬浮做不到要配合快捷键触发

    image.png

    鼠标悬浮会出文档注释

    image.png

    1 回复
  • SiYuan005

    大佬,感觉就是这个,请问怎么搞的,哪个 IDE,如何配置啊,谢谢大神!!!

    1 回复
  • yss930819

    jetbrains 的全家桶都有快捷键是 Ctrl+B 会显示引用,需要点开引用源就能看源位置的代码了。C 语言开发我用的 Clion。

    image.png

    鼠标悬浮有提示,需要代码注释写的是正确的文档注释,C 语言就是 dxygen 格式就能提示。java 需要用 javadoc 注释。

    IDE 其他功能可以慢慢挖掘

    1 回复
  • SiYuan005 1 评论

    谢谢大佬的提示,我感觉解决了一部分的问题,后续可以探索 jetbrains 的 IDE,不过需要氪金 hhhhh

    搜一下 ja-netfilter ,你懂的, 项目位于在 gitee 上
    iamqiz
请输入回帖内容 ...

推荐标签 标签

  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    536 引用 • 672 回帖 • 2 关注
  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    370 引用 • 1215 回帖 • 583 关注
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 88 关注
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    228 引用 • 1450 回帖 • 2 关注
  • FlowUs

    FlowUs.息流 个人及团队的新一代生产力工具。

    让复杂的信息管理更轻松、自由、充满创意。

    1 引用
  • 导航

    各种网址链接、内容导航。

    37 引用 • 168 回帖 • 1 关注
  • V2Ray
    1 引用 • 15 回帖 • 2 关注
  • Bootstrap

    Bootstrap 是 Twitter 推出的一个用于前端开发的开源工具包。它由 Twitter 的设计师 Mark Otto 和 Jacob Thornton 合作开发,是一个 CSS / HTML 框架。

    18 引用 • 33 回帖 • 684 关注
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    103 引用 • 294 回帖
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖 • 5 关注
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖 • 1 关注
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    40 引用 • 24 回帖
  • RabbitMQ

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

    49 引用 • 60 回帖 • 393 关注
  • Bug

    Bug 本意是指臭虫、缺陷、损坏、犯贫、窃听器、小虫等。现在人们把在程序中一些缺陷或问题统称为 bug(漏洞)。

    77 引用 • 1741 回帖
  • OpenResty

    OpenResty 是一个基于 NGINX 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

    17 引用 • 42 关注
  • etcd

    etcd 是一个分布式、高可用的 key-value 数据存储,专门用于在分布式系统中保存关键数据。

    5 引用 • 26 回帖 • 495 关注
  • IBM

    IBM(国际商业机器公司)或万国商业机器公司,简称 IBM(International Business Machines Corporation),总公司在纽约州阿蒙克市。1911 年托马斯·沃森创立于美国,是全球最大的信息技术和业务解决方案公司,拥有全球雇员 30 多万人,业务遍及 160 多个国家和地区。

    16 引用 • 53 回帖 • 122 关注
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    106 引用 • 152 回帖 • 1 关注
  • Latke

    Latke 是一款以 JSON 为主的 Java Web 框架。

    70 引用 • 532 回帖 • 713 关注
  • Laravel

    Laravel 是一套简洁、优雅的 PHP Web 开发框架。它采用 MVC 设计,是一款崇尚开发效率的全栈框架。

    19 引用 • 23 回帖 • 689 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 23 关注
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 43 关注
  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    170 引用 • 414 回帖 • 423 关注
  • 强迫症

    强迫症(OCD)属于焦虑障碍的一种类型,是一组以强迫思维和强迫行为为主要临床表现的神经精神疾病,其特点为有意识的强迫和反强迫并存,一些毫无意义、甚至违背自己意愿的想法或冲动反反复复侵入患者的日常生活。

    15 引用 • 161 回帖 • 3 关注
  • Oracle

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

    103 引用 • 126 回帖 • 446 关注
  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    207 引用 • 2031 回帖
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 293 关注