在用layui引入第三方插件或者自定义模块时报此错误,找到原因是引入的模块没有遵循模块规范,记得检查一下最后有没有 exports 暴露模块。
扩展一个 layui 模块
第一步:确认模块名,假设为:mymod,然后新建一个 mymod.js 文件放入项目任意目录下(注意:不用放入layui目录)
第二步:编写 test.js 如下:
/**
扩展一个test模块
**/
layui.define(function(exports){ //提示:模块也可以依赖其它模块,如:layui.define('layer', callback);
var obj = {
hello: function(str){
alert('Hello '+ (str||'mymod'));
}
};
//输出test接口
exports('mymod', obj);
});
第三步:设定扩展模块所在的目录,然后就可以在别的 JS 文件中使用了
//config的设置是全局的
layui.config({
base: '/res/js/' //假设这是你存放拓展模块的根目录
}).extend({ //设定模块别名
mymod: 'mymod' //如果 mymod.js 是在根目录,也可以不用设定别名
,mod1: 'admin/mod1' //相对于上述 base 目录的子目录
});
//你也可以忽略 base 设定的根目录,直接在 extend 指定路径(主要:该功能为 layui 2.2.0 新增)
layui.extend({
mod2: '{/}http://cdn.xxx.com/lib/mod2' // {/}的意思即代表采用自有路径,即不跟随 base 路径
})
//使用拓展模块
layui.use(['mymod', 'mod1'], function(){
var mymod = layui.mymod
,mod1 = layui.mod1
,mod2 = layui.mod2;
mymod.hello('World!'); //弹出 Hello World!
});
参考
扩展一个 layui 模块https://layui.dev/docs/2/modules.html
排错方法
- 是否重复引用了 layui.js?
- 文件加载的路径是否正确 ?(90%以上的原因,重点排查)
- 有没有 exports 暴露模块?
- 仔细看文档,仔细看文档,仔细看文档。