一些小特性的建议

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

建议 1 增加 Snippet 功能

才开始试用,感觉思源笔记的很多创新和借鉴的东西非常不错,非常看好这个产品的未来

使用笔记类的软件的用户,其实有多种的需求,比如我,多是进行各类自己喜欢知识的收集和整理,所以思源的网页及其 Word、Excel 的直接粘贴功能我非常的喜欢,以前为了这些剪贴,自己还专门写了相关的程序来处理。还有一类用户呢,是用笔记软件来记录或者写作,比如大学生或者论坛的写手等等,这类用户更会在意写作的流畅性,在这一点上思源笔记也做了很好的工作。

可能对一些使用过其他笔记软件的非码农,对于 Markdown 方式的写作有一点点恐惧,他们会说思源不宜入门,但有了软件的功能按钮,其实对普通用户来说,入手并没有那么难。

但是对于那些做随堂笔记的学生们,他们也许更希望能做到更快捷,更易用。

所以某种意义上的自动完成,捷显得非常有意义。

所以我建议作者可以考虑 snippets 的使用,在流行的编辑软件里,不管是 vim subline 还是 VScode,都不约而同地使用了 snippets.思源笔记在 Markdown 的文本里,集成了 MathJax、mindmap、mermaid、echarts、abc、graphviz、plantuml 这些优秀的应用,使得笔记里面可以集成公式、图表、UML 图、脑图等各种类型的功能。但这些对普通用户来说才是更难的东西。一个经常画类图、流程图的人,他可能会下一些时间去学习 plantUML,但是对于偶尔用其中一些功能的人,其实了解其中一小部分就足够用了。比如说一个学生,课堂笔记经常要输入公式,但一个学微积分的人,可能最常用的都是微积分符号,而学代数的人,也许会经常和矩阵打交道,所以如果能让他们不必完整掌握 Latex 或者 MathJax,就能很好使用的话,易用性的问题就能得到解决,同时也会成为思源笔记与其他笔记软件的差异性所在。

实现这个第一种方式,就是可以考虑使用 snippets,很成熟的一种方式

其实思源里已经有自动完成功能了,比如表情 Emoji 的输入就是一种,所以这段代码几乎是现成的了

使用 snippets 的一个考虑是,可以让用户自己定义这些自动完成的内容,而且可以让用户直接或者部分修改就是一直接使用其他软件目前大量的 snippets 资源。

调用自动完成,可以考虑使用思源原有的标点符号启用方式,也可以把 snippets 的激活定义在一个快捷键上

建议:

  • 不同类型的内容块,可以对应不同的 snippets 定义
  • 代码块中似应该针对代码语言的不同,对应不同的 snippets 定义

当然,使用和 Vscode 类似的编写 JSON 文件的方式,实现用户定义,对非 IT 用户来说未必友好,作者也可以考虑开发相应的模块来进行,可以考虑两种方式混用

其实还可以考虑增加一个可开关的浮动工具版,将定义好的 Snippet 关联在按钮上,可以给非专业者更好的体验。

建议 2 文档块增加一个将网络图片下载到本地的功能

对于我这种经常搜集文档的人,在以前使用 Markdown,总遇到一个问题,就是把 Markdown 的图片等资源保持原有链接还是下载到本地。

保持原有链接,可以减少文档及附件的尺寸,但是在没有网络的情况下或者原链接失效的情况下,就会让这类图片无法显示了。保存到本地可以在文档有大量图片的时候,仍能更好的快速显示,但是会让本地的包尺寸较大。

所以按照不同情况转换是最好的,我看到思源在剪贴文档的时候,可以选择保持原有链接,或者选择下载到本地,这个做得很好。

我认为缺省保持原链接是最好的,有特殊需求的时候,我希望可以在文件列表里增加一项功能,就是把已经做好的笔记文档里的外部链接图片,一键下载到本地,并把原来笔记里的网络连接改为本地链接

对于开发者,这个功能实现是举手之劳而已

一些建议或者说一些需求,供开发者参考

  • 思源笔记

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

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

    22017 引用 • 87794 回帖 • 2 关注

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
    • Snippet 应该就是现有的模板功能吧,不知道我理解是否有误
    • 图床功能订阅后就有了,默认是本地文件,同步时会自动上传一份到图床上,方便分享

    感谢你花时间帮助思源进步,欢迎继续讨论 ❤️

    1 回复
  • Dawn99 2 1 赞同

    我个人感觉 snippet 和现在的模板差别还蛮大的(我之前用过 vim 的 UltiSnips 插件写数学公式),主要体现在以下方面:

    • 首先是使用的便捷性,snippet 一般是无时无刻不在识别(类似于代码自动补全),但是模板需要“{{”来唤起
    • 其次 snippet 光标比较自由:可以产生多光标,或者按 Tab 键跳转光标(公式,代码等常用)
      beginend
    • 另外比较高级的 snippet 可以使用正则表达式匹配输入的内容,从而实现一些自动格式化(这个我目前只在 vim 的 UltiSnips 里面见过)
      • 例子 1:在公式(由两个$包裹的区域)中输入 alpha(alpha)会自动在前面加上\(变为\alpha
      • 例子 2:在 alpha 后输入 1(\alpha1)会自动加下标(\alpha_1
        自动加下标

    其他例子:

    高级例子

    更多例子可以见这篇文章


    这样使用 snippet 确实非常顺滑,但是一些比较高级的使用可能不好做?我感觉目前如果有需要也就是 VScode 那种:输入命名按 tab 进行补全,同时可以自定义光标的多个位置这样或许就好。

    不过目前我写数学公式,复杂的都用 ipad 手写了,而 snippet 的使用场景大多数是在代码中,所以我其实没有很大的需求。。。

    这上面就是提供一下 snippet 和模板不同之处的参考。模板或许更适合接入思源的 api 来生成大段的文字?

    1 回复
  • 谢谢,这个特性很专业啊,估计暂时做不了。

推荐标签 标签

  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 631 关注
  • JetBrains

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

    18 引用 • 54 回帖 • 1 关注
  • 人工智能

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

    132 引用 • 188 回帖
  • Ngui

    Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
    Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

    7 引用 • 9 回帖 • 387 关注
  • 百度

    百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

    63 引用 • 785 回帖 • 182 关注
  • 游戏

    沉迷游戏伤身,强撸灰飞烟灭。

    176 引用 • 815 回帖
  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 63 关注
  • RYMCU

    RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。

    4 引用 • 6 回帖 • 53 关注
  • 安装

    你若安好,便是晴天。

    132 引用 • 1184 回帖
  • 大数据

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

    93 引用 • 113 回帖
  • 工具

    子曰:“工欲善其事,必先利其器。”

    285 引用 • 728 回帖
  • 资讯

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

    55 引用 • 85 回帖 • 1 关注
  • 设计模式

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    200 引用 • 120 回帖
  • Sphinx

    Sphinx 是一个基于 SQL 的全文检索引擎,可以结合 MySQL、PostgreSQL 做全文搜索,它可以提供比数据库本身更专业的搜索功能,使得应用程序更容易实现专业化的全文检索。

    1 引用 • 210 关注
  • CongSec

    本标签主要用于分享网络空间安全专业的学习笔记

    1 引用 • 1 回帖 • 10 关注
  • WebComponents

    Web Components 是 W3C 定义的标准,它给了前端开发者扩展浏览器标签的能力,可以方便地定制可复用组件,更好的进行模块化开发,解放了前端开发者的生产力。

    1 引用 • 2 关注
  • DevOps

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

    46 引用 • 25 回帖
  • Logseq

    Logseq 是一个隐私优先、开源的知识库工具。

    Logseq is a joyful, open-source outliner that works on top of local plain-text Markdown and Org-mode files. Use it to write, organize and share your thoughts, keep your to-do list, and build your own digital garden.

    5 引用 • 62 回帖
  • HTML

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

    107 引用 • 295 回帖
  • 脑图

    脑图又叫思维导图,是表达发散性思维的有效图形思维工具 ,它简单却又很有效,是一种实用性的思维工具。

    25 引用 • 83 回帖
  • 爬虫

    网络爬虫(Spider、Crawler),是一种按照一定的规则,自动地抓取万维网信息的程序。

    106 引用 • 275 回帖
  • Thymeleaf

    Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。

    11 引用 • 19 回帖 • 354 关注
  • 大疆创新

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

    2 引用 • 14 回帖 • 1 关注
  • golang

    Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。

    497 引用 • 1387 回帖 • 294 关注
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    17 引用 • 236 回帖 • 335 关注
  • 正则表达式

    正则表达式(Regular Expression)使用单个字符串来描述、匹配一系列遵循某个句法规则的字符串。

    31 引用 • 94 回帖 • 1 关注
  • CAP

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

    11 引用 • 5 回帖 • 606 关注