跨域css加载,如何检查是否使用Javascript加载了外部(跨域)CSS文件

小编典典

这实际上是我所做的。

为了确保加载特定的CSS文件,我在CSS文件的末尾添加了样式。例如:

#ensure-cssload-8473649 {

display: none

}

现在,我有了一个JavaScript函数,它将在页面上加载上述样式时触发指定的回调:

var onCssLoad = function (options, callback) {

var body = $("body");

var div = document.createElement(constants.TAG_DIV);

for (var key in options) {

if (options.hasOwnProperty(key)) {

if (key.toLowerCase() === "css") {

continue;

}

div[key] = options[key];

}

}

var css = options.css;

if (css) {

body.appendChild(div);

var handle = -1;

handle = window.setInterval(function () {

var match = true;

for (var key in css) {

if (css.hasOwnProperty(key)) {

match = match && utils.getStyle(div, key) === css[key];

}

}

if (match === true) {

window.clearTimeout(handle);

body.removeChild(div);

callback();

}

}, 100);

}

}

这就是我使用上面函数的方式:

onCssLoad({

"id": "ensure-cssload-8473649",

css: {

display: "none"

}

}, function () {

// code when you want to execute

// after your CSS file is loaded

});

这里的第一个参数采用optionswhere id来检查 测试样式 和css属性,以验证从CSS加载的内容。

2020-05-16

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值