常用js,css文件统一加载方法,并在加载之后调用回调函数

为了方便资源管理和提升工作效率,常用的js和css文件的加载应该放在一个统一文件里面完成,也方便后续的资源维护。所以我用js写了以下方法,存放在“sourceController.js”文件内。

/**
 * Created by MingChen on 2016/11/3.
 */
function sourceController() {
    this.root = "";

    this.callfunc = null; // 回调函数

    this.css = [];

    this.script = [];

    // css数量,兼容safari用
    var cssCount = document.styleSheets.length;

    // timeOut
    var tmpTimeOut = [];

    // 时间戳
    var startTime = null;

    /**
     * 设置文件根目录
     * @param url 根目录地址
     */
    this.setRoot = function (url) {
        this.root = url;
    };

    /**
     * 设置回调函数
     * @param func 回调函数
     */
    this.setCallBack = function (func) {
        this.callfunc = func;
    };

    /** 添加Script文件 请在addSource钱调用
     * @param url script文件路径
     */
    this.addScript = function (url) {
        if (url === "" || url == null) return;
        this.script.push(url);
    };

    /**
     * 添加CSS文件 请在addSource钱调用
     * @param url css文件路径
     */
    this.addCss = function (url) {
        if (url === "" || url == null) return;
        // console.log("csslength:" + this.css.length);
        this.css.push(url);
    };

    /** 添加常用资源 */
    this.addSource = function () {
        addMeta([["name", "renderer"], ["content", "ie-comp"]]);

        createCss(this);
    };

    /**
     * 添加<link> 默认先加载css
     * @param obj 当前对象
     */
    function createCss(obj) {
        // 如果没有css文件,不加载
        if (obj.css.length <= 0) return;
        var url = obj.css.shift();
        // console.log(url);
        var css = document.createElement("link");
        css.setAttribute("rel", "stylesheet");
        if (obj.root != "") {
            url = obj.root + "/" + url;
        }
        css.href = url;

        // 老版本safari特殊处理,获取浏览器信息的方法请自己添加
        if (browserInfo().browser == "safari" && parseInt(browserInfo().version) < 6) {
            var timer = setInterval(function () {
                // console.log("timer cssCount:" + cssCount + " len:" + document.styleSheets.length);
                clearTmpTimeOut();
                if (document.styleSheets.length == cssCount && obj.css.length > 0) {
                    addTask(createCss, 0, obj);
                } else if (document.styleSheets.length == cssCount) {
                    // 如果有js文件,开始加载js
                    if (obj.script.length > 0) {
                        addTask(createJs, 0, obj);
                    } else {
                        obj.css.length = 0;
                        if (typeof obj.callfunc == "function") {
                            obj.callfunc();
                        }
                    }
                    clearInterval(timer);
                }
            }, 50);
        } else {
            css.onload = function () {
                clearTmpTimeOut();
                if (obj.css.length > 0) {
                    addTask(createCss, 0, obj);
                } else {
                    // 如果有js文件,开始加载js
                    if (obj.script.length > 0) {
                        addTask(createJs, 0, obj);
                    } else {
                        tmpTimeOut.length = 0;
                        obj.css.length = 0;
                        if (typeof obj.callfunc == "function") {
                            obj.callfunc();
                        }
                    }
                }
            };
        }
        document.getElementsByTagName("head")[0].appendChild(css);
        cssCount++;
    }

    /**
     * 添加<script> js加载完后执行回调函数
     * @param obj 当前对象
     */
    function createJs(obj) {
        // 如果没有js文件,不加载
        if (obj.script.length <= 0) return;
        var script = document.createElement('script');
        script.setAttribute('type', 'text/javascript');
        script.setAttribute('src', (obj.root) ? (obj.root + "/" + obj.script.shift()) : (obj.script.shift()));
        script.onload = script.onreadystatechange = function () {
            if (script.ready) {
                return false;
            }
            if (!script.readyState || script.readyState == "loaded" || script.readyState == 'complete') {
                script.onload = script.onreadystatechange = null;
                script.ready = true;
                clearTmpTimeOut();
                // console.log("time:" + (new Date().getTime() - startTime) + "ms " + script.getAttribute("src"));

                if (obj.script.length > 0) {
                    addTask(createJs, 0, obj);
                } else {
                    tmpTimeOut.length = 0;
                    obj.script.length = 0;
                    // 如果有回调函数 执行回调函数
                    if (typeof obj.callfunc == "function") {
                        obj.callfunc();
                    }
                }
            }
        };
        startTime = new Date().getTime();
        document.getElementsByTagName("body")[0].appendChild(script);
    }

    /**
     *添加一个任务,
     *    @param {Function} fun 任务函数名
     *    @param {number} delay 定时时间
     *    @param {object} params 传递到fun中的参数
     */
    function addTask(fun, delay) {
        var to = null;
        if (typeof fun == 'function') {
            var argu = Array.prototype.slice.call(arguments, 2);
            var f = (function () {
                fun.apply(null, argu);
            });
            to = window.setTimeout(f, delay);
            tmpTimeOut.push(to);
            return to;
        }
        to = window.setTimeout(fun, delay);
        tmpTimeOut.push(to);
    }

    // 清空加载计时器
    function clearTmpTimeOut() {
        while (tmpTimeOut.length > 0){
            var tto = tmpTimeOut.shift();
            window.clearTimeout(tto);
            tmpTimeOut.length = 0;
        }
    }
}

设置资源路径管理文件config.js。

/**
 * Created by MingChen on 2016/10/25.
 */
var sourcePath = {
    "iconfont": "css/iconfont/iconfont.css",
    "jquery": 'javascript/libs/jquery/jquery.js',
    "pieJS": "javascript/libs/PIEJS/PIE.js",
    "data": "javascript/publicData.js",
    // jquery-ui
    "cjqueryui": "css/jquery-ui.css",
    "jqueryui": 'javascript/libs/jquery/jquery-ui-1.11.4.js',
    // jqgrid
    "cjqgrid": "javascript/libs/jqgrid/ui.jqgrid.css",
    "jqgridcn":  "javascript/libs/jqgrid/grid.locale-cn.js",
    "jqgrid": "javascript/libs/jqgrid/jquery.jqGrid.js",
    // common
    "ccommon": "css/common.css",
    "common": "javascript/common.js",
    // header
    "cheader": "javascript/libs/headerMenu/css/headerMenu.css",
    "header": "javascript/libs/headerMenu/js/headerMenu.js",
    // circle
    "circle": "javascript/libs/raphael/cycle.js",
    "circleBar": "javascript/libs/raphael/raphael.js",
    // search
    "csearch": "javascript/libs/searchForm/css/searchForm.css",
    "search": "javascript/libs/searchForm/js/searchForm.js",
    // datePicker
    "datePicker": "javascript/libs/My97DatePicker/WdatePicker.js",
    // select2
    "cselect2": "javascript/libs/select2/css/select2.min.css",
    "select2min": "javascript/libs/select2/js/select2.min.js",
    "select2Func": "javascript/libs/select2/js/select2Func.js",
    // validator
    "cvalidator": "javascript/libs/validation/css/jqvForm.css",
    "validator": "javascript/libs/validation/js/jquery.validate.js",
    // dialog
    "cdialog": "javascript/libs/dialogBox/css/dialogBox.css",
    "dialog": "javascript/libs/dialogBox/js/dialogBoxUtils.js",
    // layer
    "clayer": "javascript/libs/layer/skin/layer.css",
    "layer": "javascript/libs/layer/layer.js"
};

在需要引入的页面只需要在<head>加入如下代码就可以一下子引入所有的常用资源了。为了显示美观在所有布局完成之间body设置visibility为hidden,布局完成后显示出来。

window.onload = function(){
    var sc = new sourceController();
    sc.setRoot("根目录地址");
    sc.css = [sourcePath.cjqueryui, sourcePath.cjqgrid];
    sc.script = [sourcePath.common, sourcePath.jquery, sourcePath.jqueryui, sourcePath.jqgrid];
    if(判断条件) // 根据需要额外添加的文件{ 
        sc.addCss("css/index.css"); // 额外添加的css文件,必须在加载资源之前加入
        sc.addScript("javaScript/index.js"); // 额外添加的js文件,必须在加载资源之前加入
    }
    sc.setCallBack(function(){
        document.body.style.display = "block"; // 显示body
    });
    sc.addSource(); // 加载常用的js和css文件
};

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏黄Java的地盘

提高开发效率之VS Code基础配置篇

VS Code可以通过名为代码片段的功能像编辑器中插入一段指定的文本,具体操作步骤为首选项->用户代码片段->新建全局代码片段。

2782
来自专栏安恒网络空间安全讲武堂

Jarvis-OJ平台多题WriteUp分享

题目 ## PORT51 ## LOCALHOST ## Login ## 神盾局的秘密 ## IN A Mess ## RE ## flag在管理员手里 ##...

2K10
来自专栏微信小程序开发

小程序国际化实现机制

4812
来自专栏葡萄城控件技术团队

在ASP.NET MVC5中实现具有服务器端过滤、排序和分页的GridView

背景 在前一篇文章《【初学者指南】在ASP.NET MVC 5中创建GridView》中,我们学习了如何在 ASP.NET MVC 中实现 GridView,类...

2708
来自专栏向前进

【踩坑】angularJS 1.X版本中 ng-bind 指令多空格展示

做项目的时候遇到的问题 1、问题描述   用户在表单某个值输入多个空格,例如:A     B,保存至服务器   在列表查询页面中使用bg-bind的指令单向绑定...

3463
来自专栏Spark学习技巧

Kafka源码系列之源码解析SimpleConsumer的消费过程

Kafka源码系列是以kafka 0.8.2.2源码为例讲解。浪尖纯属个人爱好,才写想写这个系列。希望对kafka的使用者们带来帮助。 一,消费者消费的过程讲解...

4757
来自专栏圣杰的专栏

Asp.net mvc 知多少(七)

本系列主要翻译自《ASP.NET MVC Interview Questions and Answers 》- By Shailendra Chauhan,想...

2335
来自专栏AILearning

Apache Zeppelin 中 Python 2&3解释器

配置 属性 默认 描述 zeppelin.python python 已经安装的Python二进制文件的路径(可以是p...

3597
来自专栏Java帮帮-微信公众号-技术文章全总结

springboot 入门教程(5) 基于ssm框架的crud操作(前端部分-附源码)

springboot 入门教程(5) 基于ssm框架的crud操作(前端部分-附源码) 上一篇介绍了spring boot整合mybatis实现了后端的CRUD...

4638
来自专栏码字搬砖

sqoop原理

sqoop,各位看官基本上都了解或者听说过,小二就不进行废话了。另外基于国内大部分用的为CDH,小二就想说一点:CDH中的sqoop2其实是apace版的sqo...

4731

扫码关注云+社区

领取腾讯云代金券