导出 pdf 后页面内引用链接失效,页面内无法跳转

去年也有人提过这个问题,现在仍然没有解决:导出为 pdf 时,页内跳转功能的引用失败 - 链滴

当前软件版本:v3.1.9

类似的问题:思源为什么不能兼容 markdown 的锚点语法 - 链滴

另外说下我的需求:

  1. 长篇幅图文编辑,本地存储
  2. 可以导出 pdf 分享,且最大限度还原导出前的浏览体验

用 typora 或者 obsidian 导出 pdf 都可以正常点击页内锚点进行跳转。但无奈 typora 篇幅长了就卡顿,obsidian 太难折腾。希望思源能优化好 pdf 分享功能。

  • 思源笔记

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

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

    21674 引用 • 85914 回帖
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    7778 引用 • 35463 回帖 • 183 关注

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • @88250 PDF 内的跳转有办法搞吗?

    1 回复
  • 88250

    我这里测试引用导出脚注后可以跳转的。

    2 回复
  • 我指的是这种点击块引用之后需要能跳转到对应的地方:

    image.png

    1 回复
  • FUN
    作者

    脚注确实可以,但是浏览体验不如锚文本,不懂思源为什么不能直接锚文本点击跳转

    1 回复
  • 88250

    导出 PDF 时仅支持转换脚注导出,从引用处可以跳转到脚注定义处。

    1 回复
  • 88250

    因为引用的定义以脚注的方式插入到末尾这样更有条理,否则没有地方放置定义块。

    1 回复
  • FUN
    作者

    那为何导出前可以锚文本点击跳转,导出后就不能了呢。如果要条理,不如前后统一,这种导出后前后不一致的阅读体验太差了。

    1 回复
  • FUN
    作者

    导出后锚文本跳转在技术上应该不是问题,不知道开发者是否注意到这个需求

    1 回复
  • 88250

    导出前是在思源应用内,所以可以使用思源的特性,比如引用浮窗等,但是导出 PDF 就没办法用这些特性了,只能找一些较为合理的方案,比如转换为脚注。

  • 88250

    前面已经解释过为什么不采用直接引用跳转了,因为定义块没有地方放,统一转换脚注是目前我们能找到的最优解。

    如果你有更好的方案可以详细描述一下,我们讨论看看。

    2 回复
  • FUN
    作者

    好吧谢谢回复,那应该就是技术上没办法这么做了。但是我又试了下脚注跳转,发现并不是跳转到被链接处,而是在文末新建了被链接的内容,相当于把锚文本整理成了文末的“参考文献”,这种方式对于长文本阅读并无帮助,只能算是无奈之举。

    微信截图 20241019123848.png

    1 回复
  • 88250

    不是技术问题,而是设计上没有比转换脚注更好的方案。我觉个例子你就明白了,比如引用 A,A 是个文档,如果不转换脚注,A 文档放置在何处?

    你现在的示例里看不到跳转定位效果是因为篇幅太短了,你试下导出用户指南首页就能看到效果了。

    2 回复
  • FUN
    作者

    个人人为思源的引用浮窗作用不大,容易遮挡原本的内容,直接点击锚文本跳转,然后“alt+←”或者鼠标侧边返回键返回到初始浏览位置,这样更符合直觉。可以参考 typora 的跳转效果,非常丝滑。

    1 回复
  • 88250

    浮窗在有的时候更方便,跳转反而比较麻烦,这个看个人使用喜好了。

  • 增加一种这样的方案行不行:

    1. 引用的是非当前文档(及其子文档)中的内容,在导出 PDF 之后转换为脚注;
    2. 引用的是当前文档(及其子文档)中的内容,在导出 PDF 之后可以直接点击跳转。
    2 回复
  • FUN
    作者

    我明白你的意思了,思源的引用源除了文章内的内容,还可以是文章外的文档等资源。但是我想要的功能是,长文本内部的跳转,引用的内容也全部是文章内的,所以不存在你说的文章外的引用。

    我发的示例不是篇幅太短看不到跳转效果,可以看到跳转效果,但是我需要的是跳转到被引用的位置,而不是跳转到文末的“参考文献”

    1 回复
  • 88250

    那混合的时候咋办?而且是无法区分混合情况的,因为可以递归引用。

    3 回复
  • FUN
    作者

    对!就是这样,@88250

  • 88250

    如果需求多了会考虑处理这种特例情况,转换脚注的方案是目前通用的最优解。

  • FUN
    作者

    引用源在文章内部还是外部这个没办法区分吗?

  • 我感觉递归引用应该不会影响跳转

  • FUN 1 赞同
    作者

    假如我要导出的文章是 A,A 里面的 a1 块 引用了文章内的 a2 块,a2 块 里又引用了 文章 B 的 b 块,那么对于导出的文章 A 来说,只需实现 a1 到 a2 的锚文本跳转即可,a2 块 到 b 块 的引用则转换为脚注。

    按理说,混用的情况包括递归引用都是可以区分的。

    1 回复
  • 88250

    那如果 b 块又引用了 A 中的块呢?脚注定义中跳转正文逻辑不对,所以现在统一为脚注。

    1 回复
  • FUN
    作者

    按照 @JeffreyChen 说的准则判断即可:b 块引用了 A 中的块,即引用的是当前文档的内容,那就是可以直接点击跳转的。

    我认为脚注适合学术论文中参考文献这种方式,也就是被引用的源不在文章内,这本身就和页内跳转这个功能没有关系,就像你说的脚注定义与跳转正文的逻辑不对。

    页内跳转是为了更方便长文本阅读,能快速的在文章内部建立联系;而脚注则是与文章外部建立联系。

    希望官方能重视这个问题,对于长文本分享 pdf 还是非常必要的。

    1 回复
  • 88250

    等后面继续收集需求再考虑吧,现在还有很多比这个重要的任务待开发,谢谢。

    1 回复
  • FUN 1
    作者

    好的,希望下次用回思源时能更好用,加油!

请输入回帖内容 ...

推荐标签 标签

  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 584 关注
  • etcd

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

    5 引用 • 26 回帖 • 521 关注
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 65 关注
  • Wide

    Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

    欢迎访问我们运维的实例: https://wide.b3log.org

    30 引用 • 218 回帖 • 619 关注
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 16 关注
  • 资讯

    资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

    55 引用 • 85 回帖
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖
  • 招聘

    哪里都缺人,哪里都不缺人。

    190 引用 • 1057 回帖
  • flomo

    flomo 是新一代 「卡片笔记」 ,专注在碎片化时代,促进你的记录,帮你积累更多知识资产。

    5 引用 • 106 回帖
  • Rust

    Rust 是一门赋予每个人构建可靠且高效软件能力的语言。Rust 由 Mozilla 开发,最早发布于 2014 年 9 月。

    58 引用 • 22 回帖 • 6 关注
  • CSS

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

    196 引用 • 537 回帖
  • Sandbox

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

    403 引用 • 1246 回帖 • 585 关注
  • Vditor

    Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。

    346 引用 • 1788 回帖
  • 钉钉

    钉钉,专为中国企业打造的免费沟通协同多端平台, 阿里巴巴出品。

    15 引用 • 67 回帖 • 345 关注
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    165 引用 • 594 回帖
  • Typecho

    Typecho 是一款博客程序,它在 GPLv2 许可证下发行,基于 PHP 构建,可以运行在各种平台上,支持多种数据库(MySQL、PostgreSQL、SQLite)。

    12 引用 • 65 回帖 • 458 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    406 引用 • 3569 回帖
  • Pipe

    Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    131 引用 • 1114 回帖 • 136 关注
  • 快应用

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

    15 引用 • 127 回帖
  • 深度学习

    深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

    52 引用 • 40 回帖 • 1 关注
  • Kubernetes

    Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。

    110 引用 • 54 回帖
  • 大数据

    大数据(big data)是指无法在一定时间范围内用常规软件工具进行捕捉、管理和处理的数据集合,是需要新处理模式才能具有更强的决策力、洞察发现力和流程优化能力的海量、高增长率和多样化的信息资产。

    93 引用 • 113 回帖
  • JetBrains

    JetBrains 是一家捷克的软件开发公司,该公司位于捷克的布拉格,并在俄国的圣彼得堡及美国麻州波士顿都设有办公室,该公司最为人所熟知的产品是 Java 编程语言开发撰写时所用的集成开发环境:IntelliJ IDEA

    18 引用 • 54 回帖
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    167 引用 • 1499 回帖
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    23 引用 • 32 回帖 • 1 关注
  • SendCloud

    SendCloud 由搜狐武汉研发中心孵化的项目,是致力于为开发者提供高质量的触发邮件服务的云端邮件发送平台,为开发者提供便利的 API 接口来调用服务,让邮件准确迅速到达用户收件箱并获得强大的追踪数据。

    2 引用 • 8 回帖 • 474 关注
  • Chrome

    Chrome 又称 Google 浏览器,是一个由谷歌公司开发的网页浏览器。该浏览器是基于其他开源软件所编写,包括 WebKit,目标是提升稳定性、速度和安全性,并创造出简单且有效率的使用者界面。

    62 引用 • 289 回帖 • 1 关注