关于引入插件体系的一些想法

本贴最后更新于 1221 天前,其中的信息可能已经时移世异

刚刚安装了思源笔记,总体使用感受是很棒的,所以也去支持了一波 XD

其他的一些关于使用体验上的一些小问题我在这里就不提了,主要是说一下关于标题上提到的插件体系的一些想法和不成熟的建议:

优点:

  1. 软件的轻量性:随着特性和新功能的增加,应用本身的启动速度应该是会受到影响到,软件本身的初衷是轻量,那么在引入第三方的组件后应该会对启动速度有所影响(内存占用的问题先不讨论了,这个其实我觉得很多人可能也不会太关心 XD),即使使用了延迟加载,也存在影响体验的可能。但是使用插件模式之后,可以规避这个问题,插件的启用与否取决于用户,不同用户对于性能和功能的权衡也不同,这个风险通过这种方式可以转移到用户端。
  2. 第三方扩展:这个是插件模式最重要的一点,当然也是应用于众多开源编辑器中最多的一点,虽然作为商业软件要维持软件本身的严谨性和健壮性,但是作为功能扩充,这个是极为重要的一环。现在开发都是组件化的,不管是开发者和用户都有可能有自己独特的需求,没有必要为了一两个不太泛用的需求去增加编辑器本身的特性和功能,从而背离上面说到的轻量性。
  3. 易于维护:将编辑器本身的维护和插件的维护剥离开,维持编辑器本身的纯洁性,修复编辑器本身带来的 bug,提升编辑器本身的使用体验才应该是第一位的,所有功能的扩充都应该是额外的工作 XD。官方插件官方维护,第三方插件第三方维护,这才是可取之道。

弊端

  1. 开发成本: 这个就不说了,想做插件的扩充开始挺难的,需要考虑标准接口,组件开发规范,插件适配等等很多问题,十分耗费时间和精力。
  2. 性能问题: 现在不太清楚,反正我知道以前我用 Atom 的时候,插件多了那个性能,啧啧啧~ 不过 vscode 是真的 nb,巨硬,yyds ~

以上都是我的个人浅见,如果觉得是胡言乱语请轻喷。不过也希望路过的大佬能指出问题,给我一个自我提高的机会 XD

  • 思源笔记

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

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

    18619 引用 • 69280 回帖

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • 感谢帮忙思考,我们大致的计划是引入“视图”:数据只读,不提供 API 进行数据写入从而降低风险。视图主要用于提供各式各样的展现,满足用户对数据查询和渲染方面的需求。

    不过在此之前,我们会先着手“主题市场”,让其他开发者可以先参与到思源笔记的开发中,熟悉社区协作和基础以后我们再着手“视图市场”。

    3 回复
  • 我也是联想到不少编辑器才有的一些想法,纯粹瞎琢磨 😄

    D 大加油~~

  • 视图这个发展思路非常靠谱

  • 个人看法:关于插件的安全性我觉得开发者不必太担心,只要在开启插件模式/引入插件时给予足够的风险提醒就行了。用思源笔记的很多朋友可能都是深度用户,其中一些人可能还有点点打造工具的强迫症(比如我 😂 ),提供未来更多的可定制性对我来说非常重要。

    就像 steam 的“创意工坊”一样,提供这样的一个平台可能能让这款软件长盛不衰,充满活力。

    视图还是插件这是两种不同的路线,各有优劣;我挺希望未来能有插件系统的,希望您再考虑考虑 😄 谢谢啦!

leejoker
个人博客 http://leejoker.github.io/ 欢迎订阅~ 北京

推荐标签 标签

  • Caddy

    Caddy 是一款默认自动启用 HTTPS 的 HTTP/2 Web 服务器。

    10 引用 • 54 回帖 • 130 关注
  • 音乐

    你听到信仰的声音了么?

    59 引用 • 509 回帖
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    164 引用 • 407 回帖 • 526 关注
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 293 关注
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    675 引用 • 535 回帖
  • etcd

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

    5 引用 • 26 回帖 • 492 关注
  • Pipe

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

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

    131 引用 • 1114 回帖 • 150 关注
  • Oracle

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

    103 引用 • 126 回帖 • 453 关注
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖
  • Q&A

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

    6522 引用 • 29305 回帖 • 248 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 635 关注
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 597 关注
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • C++

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

    106 引用 • 152 回帖 • 1 关注
  • 黑曜石

    黑曜石是一款强大的知识库工具,支持本地 Markdown 文件编辑,支持双向链接和关系图。

    A second brain, for you, forever.

    10 引用 • 85 回帖
  • 阿里云

    阿里云是阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。

    89 引用 • 345 回帖 • 1 关注
  • Ant-Design

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

    17 引用 • 23 回帖
  • 创造

    你创造的作品可能会帮助到很多人,如果是开源项目的话就更赞了!

    172 引用 • 990 回帖
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    333 引用 • 323 回帖 • 70 关注
  • 服务

    提供一个服务绝不仅仅是简单的把硬件和软件累加在一起,它包括了服务的可靠性、服务的标准化、以及对服务的监控、维护、技术支持等。

    41 引用 • 24 回帖 • 4 关注
  • InfluxDB

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

    2 引用 • 54 关注
  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    59 引用 • 29 回帖 • 15 关注
  • Thymeleaf

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

    11 引用 • 19 回帖 • 317 关注
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    76 引用 • 421 回帖
  • 星云链

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

    3 引用 • 16 回帖 • 5 关注
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    9 引用 • 32 回帖 • 168 关注