本篇文章展示了layui中模块化和非模块化的区别以及使用方法具体操作,代码简明扼要容易理解,绝对能让你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
Redis的模块采用的是动态链接库的方式,可以启动的时候加载,也可以在运行时加载(MODULE LOAD),在Linux系统里面,可以通过dlopen,dlsym等实现动态加载库,在业务系统里面,经常用于将业务代码和框架代码进行分离,以实现插件化开发。在Redis里面也是同样的道理。要实现分离,首先需要的是初始化,以便让框架可以找到对应的方法,这就需要进行注册,Redis通过RedisModule_Init方法进行注册模块,和RedisModule_CreateCommand注册自定义方法。
Redis进行模块化,可以扩大Redis的生态圈,满足一些扩展性功能需求,现在就有一个Hub用于收集Redis模块的插件。
非模块化和模块化的区别是
非模块化不用每次都调用layui.use([],fun...)引入对应模块,引入的JS是/layui/layui.all.js
模块化必须每次都调用layui.use([],fun...)引入对应模块,引入的JS是/layui/layui.js (推荐这种,但是写起来不太方便)
/layui/layui.js会包含/layui/layui.js的所有功能,引入这个JS会加载所有的模块,无需自动引入模块,会使layui失去模块化的意义,但是写起来确实方便多了。因此layui官方推荐使用模块化的方式。
1、模块化的使用:
注意:引入的JS是: /layui/layui.js
遵循 layui 的模块规范建立一个入口文件,并通过 layui.use() 方式来加载该入口文件
例如:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>模块化的使用</title>
<link rel="stylesheet" href="./layui/css/layui.css">
<!--引入这个JS-->
<script type="text/javascript" src="./layui/layui.js"></script>
</head>
<body>
<script>
/*必须使用这个方法先引用对应的模块*/
layui.use(['layer'],function () {
var layer = layui.layer;
layer.alert("xxxxxxxxxxxxxxxxxxxxxxxx")
})
</script>
</body>
</html>
补充:为了方便使用可以使用下面方法引入:
function deleteDictBatch(){
var form,layer;
layui.use(['form','layer'],function () {
form = layui.form;
layer=layui.layer;
});
//获取选中的元素的个数
var length_1 = $("[name='dictionaryCheckbox']:checked").length;
//1.如果选中的个数为0,直接退出函数,提示选择字典删除
if(length_1 ==0 ){
layer.alert("请选中需要删除的字典")
return ;
}
//如果有元素需要被删除
else{
if(!confirm("您确认要删除下列字典?")){//点取消也退出函数
return;
}
//第二种方式,以数组的方式去提交。后台用string接收
var values = [];
$("[name='dictionaryCheckbox']:checked").each(function (i) {//i代表索引
values[i]=$(this).val();
})
$.post(contextPath+'/dictionary/deleteDictBatch.do',{dictionaryIds:values.toString()},function(response){
alert(response);
if(response == "删除成功"){
getDictionaryTree();//查询字典树
getDictionaryFY();//分页查询字典信息
}
},'text')
//删除的业务逻辑
}
}
也可以将layer和form作为全局变量引入使用:
/**
* @author: qlq
* @time: 9:31
* @description: 添加培养方案的JS
*/
/**
* 一次性自调函数初始化两个全局变量
*/
var lyer,form;
(function () {
layui.use(['layer','form'],function () {
layer=layui.layer,form=layui.form;
})
})();
/**
* 页面加载完成后执行一些函数
*/
$(function () {
layer.msg("消息框")
});
/**********S *****************/
2、非模块化的使用:
注意:引入的JS是 /layui/layui.all.js
采用“一次性加载”的方式。当你采用这样的方式时,你无需再通过 layui.use() 方法加载模块,直接使用即可,如:
例如:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>非模块化的使用方法</title>
<link rel="stylesheet" href="./layui/css/layui.css">
<!--引入这个JS-->
<script type="text/javascript" src="./layui/layui.all.js"></script>
</head>
<body>
<script>
var layer = layui.layer;
layer.alert("xxxxxxxxxxxxxxxxxxxxxxxx")
</script>
</body>
</html>
3、补充
1.在模块法中不能直接使用非模块化的方法
例如:(下面引入是模块化JS却使用非模块化方法报错)
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>模块化的使用</title>
<link rel="stylesheet" href="./layui/css/layui.css">
<!--引入这个JS-->
<script type="text/javascript" src="./layui/layui.js"></script>
</head>
<body>
<script>
var layer = layui.layer;
layer.alert("xxxxxxxxxxxxxxxxxxxxxxxx")
</script>
</body>
</html>
2.非模块化中可以使用模块化
例如:下面正常运行,但是没必要
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>非模块化的使用方法</title>
<link rel="stylesheet" href="./layui/css/layui.css">
<!--引入这个JS-->
<script type="text/javascript" src="./layui/layui.all.js"></script>
</head>
<body>
<script>
layui.use(['layer'],function () {
var layer = layui.layer;
layer.alert("xxxxxxxxxxxxxxxxxxxxxxxx")
})
</script>
</body>
</html>
3.同时引入模块化和非模块化的话可以使用非模块化方法,但是非模块化的JS必须在模块化之后引入
例如:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>模块化的使用</title>
<link rel="stylesheet" href="./layui/css/layui.css">
<!--引入这个JS-->
<script type="text/javascript" src="./layui/layui.js"></script>
<script type="text/javascript" src="./layui/layui.all.js"></script>
</head>
<body>
<script>
/*必须使用这个方法先引用对应的模块*/
var layer = layui.layer;
layer.alert("xxxxxxxxxxxxxxxxxxxxxxxx")
</script>
</body>
</html>
看完上述内容,你们掌握layui中模块化和非模块化的使用方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注天达云行业资讯频道,感谢各位的阅读!