详解开源的JavaScript插件化框架MinimaJS


Posted in Javascript onOctober 26, 2017

本文介绍我开发的一个JavaScript编写的插件化框架——MinimaJS,完全开源,源码下载地址:https://github.com/lorry2018/minimajs。该框架参考OSGi规范,将该规范定义的三大插件化功能在Node上实现了。MinimaJS三个功能:动态插件化,服务和扩展。该框架基于VSCode开发、使用ES6编码,基于Node 8开发,代码量几千行,非常的简单、优雅、轻量。框架的代码结构划分清晰,命名优雅。

我们先简单看一下,如何来使用这个框架。

通过这几行代码就可以创建一个插件框架,并且从当前的plugins目录下加载插件。

每一个插件在plugins目录下,由plugin.json来定义插件的基本信息、依赖信息、服务和扩展,该文件必须在插件根目录下,并且包含。一个插件由plugin.json和其它文件构成,其它文件为可选,可以包括js、html、css文件等。如下为一个插件示例。对于plugin.json文件,除了id是必填属性,其它均为可选,这意味着最小的插件为一个只定义了plugin.json且该文件只声明插件id。

详解开源的JavaScript插件化框架MinimaJS

通OSGi规范类似,每一个插件可以定义一个激活器,默认为Activator.js,如果命名不是默认值,则需要在plugin.json里面通过activator定义该激活器文件名。一个典型的Activator定义如下,用于声明插件的入口和出口。

这里start与stop分别代表入口和出口,用于服务注册、绑定、事件监听等。

插件间通过服务进行通讯,一个插件注册服务,一个插件消费服务。插件注册可以通过plugin.json来声明,也可以通过激活器start方法的PluginContext参数的addService来注册服务。如下所示,使用plugin.json来注册一个服务。

另一个插件,可以通过激活器来消费服务。

该框架还提供了插件扩展、类加载等特性,可以通过框架提供的实例来探索。以下是一个插件化的REST框架,基于插件化构建的实例,可以通过源码下载获取。

详解开源的JavaScript插件化框架MinimaJS

这个示例演示了Express、Art-Template、WebAPI框架、插件动态扩展、Web轻量框架的构建,详细可以查看实例。

 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript中Object和Function的关系小结
Sep 26 Javascript
jquery选择器的选择使用及性能介绍
Jan 16 Javascript
JavaScript继承基础讲解(原型链、借用构造函数、混合模式、原型式继承、寄生式继承、寄生组合式继承)
Aug 16 Javascript
浅谈javascript属性onresize
Apr 20 Javascript
jquery中键盘事件小结
Feb 24 Javascript
浅谈jquery的html方法里包含特殊字符的处理
Nov 30 Javascript
javascript工厂模式和构造函数模式创建对象方法解析
Dec 30 Javascript
JS实现JSON.stringify的实例代码讲解
Feb 07 Javascript
vue2.0中vue-cli实现全选、单选计算总价格的实例代码
Jul 18 Javascript
vue2.x 通过后端接口代理,获取qq音乐api的数据示例
Oct 30 Javascript
ant-design-vue 实现表格内部字段验证功能
Dec 16 Javascript
JavaScript 防篡改对象的用法示例
Apr 24 Javascript
Angular搜索 过滤 批量删除 添加 表单验证功能集锦(实例代码)
Oct 25 #Javascript
js插件实现图片滑动验证码
Sep 29 #Javascript
使用Bootstrap和Vue实现用户信息的编辑删除功能
Oct 25 #Javascript
详解JSONObject和JSONArray区别及基本用法
Oct 25 #Javascript
详解HTML5 使用video标签实现选择摄像头功能
Oct 25 #Javascript
vue 数组和对象不能直接赋值情况和解决方法(推荐)
Oct 25 #Javascript
JS使用tofixed与round处理数据四舍五入的区别
Oct 25 #Javascript
You might like
PHP引用返回用法示例
2016/05/28 PHP
PHP连接MySQL数据库并以json格式输出
2018/05/21 PHP
Mootools 1.2教程 输入过滤第一部分(数字)
2009/09/15 Javascript
基于jquery的让textarea自适应高度的插件
2010/08/03 Javascript
在IE浏览器中resize事件执行多次的解决方法
2011/07/12 Javascript
JS TextArea字符串长度限制代码集合
2012/10/31 Javascript
javascript 判断字符串是否包含某字符串及indexOf使用示例
2013/10/18 Javascript
javascript图片相似度算法实现 js实现直方图和向量算法
2014/01/14 Javascript
js获取当前地址 JS获取当前URL的示例代码
2014/02/26 Javascript
javascript实现拖放效果
2015/12/16 Javascript
值得分享的bootstrap table实例
2016/09/22 Javascript
canvas实现爱心和彩虹雨效果
2017/03/09 Javascript
nodejs 子进程正确的打开方式
2017/07/03 NodeJs
jQuery实现的简单动态添加、删除表格功能示例
2017/09/21 jQuery
vue2.0+koa2+mongodb实现注册登录
2018/04/10 Javascript
[02:35]DOTA2英雄基础教程 末日使者
2013/12/04 DOTA
python 七种邮件内容发送方法实例
2014/04/22 Python
处理Python中的URLError异常的方法
2015/04/30 Python
Python调用系统底层API播放wav文件的方法
2017/08/11 Python
Python实现简单的HttpServer服务器示例
2017/09/25 Python
python取余运算符知识点详解
2019/06/27 Python
Python OpenCV读取显示视频的方法示例
2020/02/20 Python
pycharm 使用tab跳出正在编辑的括号(){}{}等问题
2021/02/26 Python
突袭HTML5之Javascript API扩展3—本地存储全新体验
2013/01/31 HTML / CSS
canvas因为图片资源不在同一域名下而导致的跨域污染画布的解决办法
2019/01/18 HTML / CSS
中国最大隐形眼镜网上商城:视客眼镜网
2016/10/30 全球购物
请编程遍历页面上所有 TextBox 控件并给它赋值为 string.Empty
2015/12/03 面试题
幼儿教师考核制度
2014/01/25 职场文书
蜜蜂引路教学反思
2014/02/04 职场文书
趣味运动会活动方案
2014/02/12 职场文书
工作说明书范文
2014/05/07 职场文书
国际语言毕业生求职信
2014/07/08 职场文书
无私奉献演讲稿
2014/09/04 职场文书
小学远程教育工作总结
2015/08/13 职场文书
2019运动会广播加油稿汇总
2019/08/21 职场文书
python 爬取豆瓣网页的示例
2021/04/13 Python