您的位置 首页 技术

layui的模块化和非模块化使用(附代码)

非模块化和模块化的区别是 非模块化不用每次都调用layui.use([],fun…)引入对应模块,引入的JS是/layui/layui.all.js 模块化必须每次都调…

非模块化和模块化的区别是

非模块化不用每次都调用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的模块化和非模块化使用(附代码)的详细内容,更多请关注24课堂在线网其它相关文章!

本文来自网络,不代表24小时课堂在线立场,转载请注明出处:https://www.24ketang.cn/12599.html

为您推荐

返回顶部