Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/janryWang/kvm
KVM.js 轻量级模块管理器,依赖注入,AMD,Commonjs规范,Promise化
https://github.com/janryWang/kvm
Last synced: 2 months ago
JSON representation
KVM.js 轻量级模块管理器,依赖注入,AMD,Commonjs规范,Promise化
- Host: GitHub
- URL: https://github.com/janryWang/kvm
- Owner: janryWang
- Created: 2015-03-05T11:56:52.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2018-06-29T14:18:39.000Z (over 6 years ago)
- Last Synced: 2024-11-09T03:42:26.839Z (2 months ago)
- Language: JavaScript
- Homepage: https://github.com/janryWang/kvm
- Size: 2.7 MB
- Stars: 41
- Watchers: 2
- Forks: 5
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-github-star - kvm
README
KVM.js 模块管理器(v0.2.0),带给你不一样的模块管理体验
支持AMD,CMD规范,支持依赖注入,支持插件式加载脚本
>如果你需要做一个浏览器书签,或者chrome插件,或者第三方组件,对于嵌入到对方网站上的情况,
>你不能保证对方是否已经存在有你所依赖的相关库,这样就可能存在浪费资源的情况,所以我添加了冲突检测机制
>使得该加载器更加智能化#bower安装
```
bower install kvm
```
#更新日志v0.2.0
===
* 修复commonjs在safari下的性能问题
* ES6重构,兼容至IE9
* 将插件全部作为独立包
* 支持在路径中直接添加querystring或者hashstring来作为版本迭代指令或者第三方插件指令v0.1.5
===
* 重构,将内部模块解耦,以Promise为核心,可通过模块返回Promise对象来延迟加载依赖
* 依赖可以依赖css,在querystring中使用media="xxxx"可以控制响应式样式表范围
* 添加了插件模式,可以随意的给kvm添加各种插件v0.1.0
===* 已做添加包管理机制
* 已添加cmd规范支持
* 性能提升,实测为requirejs的2倍多
* 因为维护时间有限,已经放弃mini版本的维护,非常抱歉.#API接口
KVM.module
* KVM.module.define 定义模块,这里,全局define也可以定义模块
```
define([dep1,dep2,....],function(dep1,dep2,...){ //定义匿名模块
})
define([dep1,dep2,....,function(dep1,dep2,...){ //定义匿名模块,angular风格
}])
define(function(){ //定义匿名模块,无依赖
})
define(["require","exports","module"],function(require,exports,module){//commonjs风格
var depA = require("depA");module.exports = function(){
return depA.fun();
};or
exports.fun = function(){
return depA.fun();
};
})
定义id模块,id就是模块路径
define(id,后面的和匿名定义模块一样)
定义注入的依赖
define(id,deps,facotry,injectors)injectors的规范:
{
module_id:[dep1,dep2,dep3,...,fucntion(dep1,dep2,dep3){//这里可以是数组也可以是函数,随便你怎样搞}]
}
```* KVM.module.invoke 调用模块
```
KVM.module.invoke('{module id}',injectors) //调用模块,可以指定模块路径,injectors是临时注入的依赖,同时它也能依赖其他模块
KVM.module.invoke([dep1,dep2,...,function(dep1,dep2,...){ //调用匿名模块,通常用于临时将某些依赖合并使用
}],injectors);injectors的规范:
{
module_id:[dep1,dep2,dep3,...,fucntion(dep1,dep2,dep3){//这里可以是数组也可以是函数,随便你怎样搞
}]
}
invoke调用后返回的结果是一个promise对象,所以通过then可以获得模块的实例
```* KVM.module.use 使用某一模块,功能单一,没有注入依赖的功能
```
KVM.module.use('id',function(instance){//仅仅只能使用id来调用,不能像invoke一样调用一个匿名工厂
});
```
* KVM.module.config 参数配置
```
KVM.module.config(options);
options = {
baseUrl:"",//项目基础路径,这个对于按需加载应用来说是必须要配置
shims:{//模块包装器,主要是为了兼容第三方模块
angular:{
url:"",
facotry:[deps,function(){//这里定义facotry可以是数组也可以是函数,随便你怎样搞
return angular
}],
exports:"$"//该字段针对于注入到全局作用域的第三方组件的组件名,可以用其替代factory,也能自动检测冲突,比如该例子,如果$存在于全局域中,系统就不会再请求脚本了
}
},
vars:{
mod:"./modules",
hello:"{mod}/hello"//变量中可以互相重用
},
alias:{//路径别名,就是为了懒人准备的
player:"{mod}/Player"//这样映射后每次依赖的时候就不需要每次都使用长长的路径id了,同时还支持别名路径的重用,通过使用{}语法来链接vars中的属性
},
packages:{//包管理机制
packageName:{
url:""//包路径
}
}
}
```
* KVM.module.data 返回当前配置
```
KVM.module.data(name);如果name为空返回所有配置,如果name不为空则返回相应的配置项
```KVM.isArray 判断是否是数组
KVM.isString 判断是否是字符串
KVM.isObject 判断是否是对象,这个对象不包括数组
KVM.isFunction 判断是否是函数
KVM.isBoolean 判断是否是布尔值
KVM.isReference 判断是否是引用类型
KVM.isValue 判断是否是值类型
KVM.isEmpty 判断对象是否为空,可以判断数组也可以判断对象
###内置模块接口
####$emitter 事件分发器
```
var event = new $emitter(cache/*外部缓存事件队列*/);event.$on(“eventName”,callback) 注册事件
event.$emit("eventName",param1,param2,....) 触发事件
event.$remove("eventName",callback) 删除事件
event.$one("eventName",callback) 注册事件,对于一个事件名只能注册一个事件处理器
```
###插件接口
```
kvm.module.registerPlugin(function(interface){
....
});这是相关暴露出来的插件接口
let PluginInterface = {
registerModuleParser: Module.registerModuleParser,//用于模块解析,参造commonjs插件registerDriverLoader: Driver.registerDriverLoader,//用于各种加载驱动程序
registerDriverLoaded: Driver.registerDriverLoaded,//驱动加载后的回调
registerDriverBeforeLoad: Driver.registerDriverBeforeLoad,//驱动加载前的回调registerFileExtParser: Path.registerFileExtParser,//文件后缀解析器
registerPathParser: Path.registerPathParser,//路径解析器
registerPathMaper: Path.registerPathMaper,//路径映射解析器createModule: Module.createModule,//创建一个模块
createPath: Path.createPath//创建一个path
};```