Skip to content

Latest commit

 

History

History
84 lines (66 loc) · 1.76 KB

README.md

File metadata and controls

84 lines (66 loc) · 1.76 KB

fis3-hook-amd_enhancejs

AMD模块增强规范的fis3实现

  • 自动引用模块
  • 增强模块功能

使用

fis.hook('amd_enhancejs', {
    // js文件名后缀,默认:['.js', '.coffee', '.jsx', '.es6']
    extList: [],

    // ...
    // 其他属性参照:fis3-hook-amd
});

语法

support

模块自动依赖,被支持模块自动引用当前模块

// 语法规则等同es6模块import
// support ... from 'path'

// 扩展 inspire()
// 增强 enhance.main
support main from './main'

// 扩展 inspire(), inspire.x(), ...
// 增强 enhance.all, enhance.all.x
support * as all from "./main"

// 扩展 inspire.foo(), inspire.bar()
// 增强 enhance.foo, enhance.mainBar
support {
    foo,
    bar as mainBar
} from './main'

inspire

模块接口扩展,可在对应运行时机传递相关参数进行功能扩展(用于被支持模块)

// 调用时扩展接口
// inspire(arg1, [...arg]);

define([], function() {
    var opt = {};
    var fun = () => {}

    inspire(opt, fun);

    setTimeout(function () {
        inspire.time(fun);
    }, 0);
});

注意:不支持inspire[name](), inspire['name']()调用

enhance

模块接口增强,扩展support引入的属性

define([], function() {
    // 仅可增强声明过的属性
    support api from 'api'

    // 在api模块,inspire调用时运行
    enhance.api = function(arg1, arg2) {};

    // 必须显式返回`enhance`
    return {
        enhance: enhance
    };
});

注意:enhance的赋值必须为函数,且必须显式返回enhance

注意

  • 每一个文件为一个模块,即define一次
  • 每个模块必须严格参照amd规范:define([], function() {})
  • 禁止循环增强