• 技术文章 >web前端 >Layui教程

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

    尚2019-11-26 17:38:02转载750

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

    非模块化不用每次都调用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中文网其它相关文章!

    声明:本文转载于:博客园,如有侵犯,请联系admin@php.cn删除
    专题推荐:layui
    上一篇:layui中创建table的方法 下一篇:layui入门总结
    大前端线上培训班

    相关文章推荐

    • 让layui支持es5写法的方法介绍• webpack打包layui实现步骤• 采用layui的美化时保留select里面的change事件• Layui table组件相关介绍

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网