非模組化和模組化的區別是
非模組化不用每次都呼叫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知識請關注layui使用教程欄目。
以上是layui的模組化和非模組化使用(附程式碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!