动态加载css样式表并等待它加载

mes*_*eeb 6 css document-ready

我有一个脚本,我在按下这样的按钮时加载一个CSS样式表:

link = "<link class='listcss' rel='stylesheet' href='http://....list.css'>";
$("head").append(link);
Run Code Online (Sandbox Code Playgroud)

然后我需要根据css的width和height属性做一些计算:

function CSSDone(){
            if($(window).width()>640){
                $(".grid-item").css({"height":$(".grid-item").width()*0.2});
                $(".grid_item_img").css({"height":$(".grid-item").width()*0.2});
            console.log("a");
            }else{
                $(".grid-item").css({"height":$(".grid-item").width()*0.33});
                $(".grid_item_img").css({"height":$(".grid-item").width()*0.33});
            console.log("b");       
            }
        }
        CSSDone();
Run Code Online (Sandbox Code Playgroud)

但是,如果我启动CSSDone(); 在添加样式表之后,计算在加载css之前发生.我疯狂搜索网页,但我尝试的一切都不起作用:

我试过这些选项:1)不起作用:

link.onload = function () {
    CSSDone();
}
Run Code Online (Sandbox Code Playgroud)

2)不起作用:

    if (link.addEventListener) {
      link.addEventListener('load', function() {
        CSSDone();
      }, false);
    }
Run Code Online (Sandbox Code Playgroud)

3)不起作用:

    link.onreadystatechange = function() {
      var state = link.readyState;
      if (state === 'loaded' || state === 'complete') {
        link.onreadystatechange = null;
        CSSDone();
      }
    };
Run Code Online (Sandbox Code Playgroud)

4)不起作用:

    $(window).load(function () {
        CSSDone();
    });
Run Code Online (Sandbox Code Playgroud)

5)不起作用:

    $(window).bind("load", function() {
        CSSDone();
    });
Run Code Online (Sandbox Code Playgroud)

相信我.什么都行不通......


一个解决方法:

我在DOM中加载css并使用jQuery再次删除它.这样,当稍后将链接添加到头部时,它足够快.

Tea*_*der 16

您需要link在头部插入一个节点,然后将onload事件附加到该节点.在您的代码链接中是一个字符串.请参阅下面的示例代码,了解如何实现您想要的功能.

var link = document.createElement('link');
link.setAttribute("rel", "stylesheet");
link.setAttribute("type", "text/css");
link.onload = function(){ CSSDone(); }
link.setAttribute("href", 'https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css');
document.getElementsByTagName("head")[0].appendChild(link);
Run Code Online (Sandbox Code Playgroud)

的jsfiddle

  • `link.onload = CSSDone` ....没有理由拥有一个除了调用另一个函数之外什么都没有的匿名函数。 (3认同)