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

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

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

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

优点:

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

弊端

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

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

  • 思源笔记

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

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

    18689 引用 • 69760 回帖 • 2 关注

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • 我也是联想到不少编辑器才有的一些想法,纯粹瞎琢磨 😄

    D 大加油~~

  • 其他回帖
  • 视图这个发展思路非常靠谱

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

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

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

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

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

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

推荐标签 标签

  • 人工智能

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

    75 引用 • 145 回帖
  • 反馈

    Communication channel for makers and users.

    123 引用 • 906 回帖 • 192 关注
  • OpenShift

    红帽提供的 PaaS 云,支持多种编程语言,为开发人员提供了更为灵活的框架、存储选择。

    14 引用 • 20 回帖 • 603 关注
  • Kubernetes

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

    108 引用 • 54 回帖
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 38 关注
  • 开源中国

    开源中国是目前中国最大的开源技术社区。传播开源的理念,推广开源项目,为 IT 开发者提供了一个发现、使用、并交流开源技术的平台。目前开源中国社区已收录超过两万款开源软件。

    7 引用 • 86 回帖
  • GAE

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

    14 引用 • 42 回帖 • 687 关注
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 692 关注
  • 书籍

    宋真宗赵恒曾经说过:“书中自有黄金屋,书中自有颜如玉。”

    76 引用 • 390 回帖
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1083 引用 • 3461 回帖 • 286 关注
  • Swift

    Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。

    34 引用 • 37 回帖 • 497 关注
  • ReactiveX

    ReactiveX 是一个专注于异步编程与控制可观察数据(或者事件)流的 API。它组合了观察者模式,迭代器模式和函数式编程的优秀思想。

    1 引用 • 2 回帖 • 126 关注
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖 • 1 关注
  • 创造

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

    173 引用 • 990 回帖 • 1 关注
  • 锤子科技

    锤子科技(Smartisan)成立于 2012 年 5 月,是一家制造移动互联网终端设备的公司,公司的使命是用完美主义的工匠精神,打造用户体验一流的数码消费类产品(智能手机为主),改善人们的生活质量。

    4 引用 • 31 回帖 • 11 关注
  • Elasticsearch

    Elasticsearch 是一个基于 Lucene 的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于 RESTful 接口。Elasticsearch 是用 Java 开发的,并作为 Apache 许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。

    116 引用 • 99 回帖 • 267 关注
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    41 引用 • 130 回帖 • 294 关注
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    69 引用 • 190 回帖 • 494 关注
  • Node.js

    Node.js 是一个基于 Chrome JavaScript 运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞 I/O 模型而得以轻量和高效。

    138 引用 • 268 回帖 • 194 关注
  • Tomcat

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

    162 引用 • 529 回帖 • 3 关注
  • Log4j

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

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

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 512 关注
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 45 关注
  • 资讯

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

    53 引用 • 85 回帖
  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    140 引用 • 441 回帖 • 1 关注
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    28 引用 • 108 回帖
  • IBM

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

    16 引用 • 53 回帖 • 124 关注