- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
有一个 similar post already ,但我觉得它不能很好地回答我的特定问题。
我想检查外部样式表是否已加载。例如,如果它受到网络问题的阻碍,那么我想知道并加载回退。这是 jQuery 主题 CSS 的 CDN 的后备 ,但我不希望它最终专门针对那个,因为我有其他我想应用的外部 CSS这也是。
link
元素将出现在页面上,因此不接受头部中存在 link 元素的模式匹配。编辑:一个新想法。如果样式表是通过 AJAX 加载的,并且检查了状态代码呢?这是一个可行的选择吗,有人知道吗?
这是我目前的脚本:
<script type="text/javascript">
var cdn = 'http://code.jquery.com/ui/1.10.1/themes/black-tie/jquery-ui.min.css';
var ss = document.styleSheets;
for (var i = 0, max = ss.length; i < max; i++) {
var sheet = ss[i];
var rules = sheet.rules ? sheet.rules : sheet.cssRules;
if (sheet.href == cdn) {
if ( rules == null || rules.length == 0) {
var link = document.createElement("link");
link.rel = "stylesheet";
link.href = '/js/jquery-ui/1.10.1/themes/black-tie/jquery-ui.min.css';
document.getElementsByTagName("head")[0].appendChild(link);
}
break;
}
}
</script>
我在使用控制台 (Chrome v25.0.1364.172) 时发现,即使样式表已从 CDN 加载,document.styleSheets[x].rules
也是 空
。我不确定我是否在控制台中正确访问它,也许我应该使用或反对另一个功能?
CSSStyleSheet {rules: null, cssRules: null, ownerRule: null, media: MediaList, title: null…}
cssRules: null
disabled: false
href: "http://code.jquery.com/ui/1.10.1/themes/black-tie/jquery-ui.min.css"
media: MediaList
ownerNode: link
ownerRule: null
parentStyleSheet: null
rules: null
title: null
type: "text/css"
__proto__: CSSStyleSheet
如果有人能帮助我找到如何检查样式表是否已加载,那将非常有帮助并且非常感谢。
最佳答案
查看生产代码 the github repo for the rack-jquery_ui-themes library .忽略常量的所有插值和大写符号,如 :THEME
,它们会在别处被替换。想象一下它是原始的 javascript。
非常感谢 Brian 在对我的问题的评论中提供了这方面的主要灵感来源。
<meta id='rack-jquery-ui-themes-fallback-beacon' />
<script type="text/javascript">
var meta = $("#rack-jquery-ui-themes-fallback-beacon");
meta.addClass("ui-icon");
if ( meta.css('width') != "16px" ) {
$('<link rel="stylesheet" type="text/css" href="/js/jquery-ui/#{JQueryUI::JQUERY_UI_VERSION}/themes/:THEME/#{JQUERY_UI_THEME_FILE}" />').appendTo('head');
}
meta.remove();
</script>
添加元标记,然后从 jQuery UI 样式表应用 CSS 类,然后检查它是否已更改,如果没有更改则添加回退链接,然后 删除元标记。
我们在头部使用元标记而不是在正文中使用 div 之类的东西是有原因的。大多数 CSS 文件都包含在头部的链接元素中。如果检查它是否加载的脚本紧随其后,因为它在头部的上下文中,所以主体还没有加载到 DOM 中。在该上下文中访问 document.body 将导致空引用错误。
<script type="text/javascript">
$.ajax({
type: "HEAD",
url: ':CDNURL',
success: function(css,status) {
// do nothing
},
error: function(xhr,status,error) {
var link = document.createElement("link");
link.rel = "stylesheet";
link.href = ':FALLBACK_URL';
document.getElementsByTagName("head")[0].appendChild(link);
}
});
</script>
我发现 this is a potential security threat所以浏览器不会允许它。
<script type="text/javascript">
var has_jquery_rules = false;
var i = document.styleSheets.length - 1;
while (i >= 0 ) {
var sheet = document.styleSheets[i];
if(sheet.href == ":CDNURL/ui/#{JQueryUI::JQUERY_UI_VERSION}/themes/:THEME/jquery-ui.min.css") {
var rules = sheet.rules ? sheet.rules : sheet.cssRules;
has_jquery_rules = rules.length == 0 ? false : true;
break; // end the loop.
}
has_jquery_rules = false;
i--;
}
if ( has_jquery_rules == false ) {
$('<link rel="stylesheet" type="text/css" href="/js/jquery-ui/#{JQueryUI::JQUERY_UI_VERSION}/themes/:THEME/#{JQUERY_UI_THEME_FILE}" />').appendTo('head');
}
</script>
这也行不通,因为某些(全部?)浏览器会阻止访问外部样式表添加的规则。
关于javascript - 检查外部样式表是否已加载以备后备,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17666785/
我有一个 if 语句,如下所示 if (not(fullpath.lower().endswith(".pdf")) or not (fullpath.lower().endswith(tup
然而,在 PHP 中,可以: only appears if $foo is true. only appears if $foo is false. 在 Javascript 中,能否在一个脚
XML有很多好处。它既是机器可读的,也是人类可读的,它具有标准化的格式,并且用途广泛。 它也有一些缺点。它是冗长的,不是传输大量数据的非常有效的方法。 XML最有用的方面之一是模式语言。使用模式,您可
由于长期使用 SQL2000,我并没有真正深入了解公用表表达式。 我给出的答案here (#4025380)和 here (#4018793)违背了潮流,因为他们没有使用 CTE。 我很欣赏它们对于递
我有一个应用程序: void deleteObj(id){ MyObj obj = getObjById(id); if (obj == null) { throw n
我的代码如下。可能我以类似的方式多次使用它,即简单地说,我正在以这种方式管理 session 和事务: List users= null; try{ sess
在开发J2EE Web应用程序时,我通常会按以下方式组织我的包结构 com.jameselsey.. 控制器-控制器/操作转到此处 服务-事务服务类,由控制器调用 域-应用程序使用的我的域类/对象 D
这更多是出于好奇而不是任何重要问题,但我只是想知道 memmove 中的以下片段文档: Copying takes place as if an intermediate buffer were us
路径压缩涉及将根指定为路径上每个节点的新父节点——这可能会降低根的等级,并可能降低路径上所有节点的等级。有办法解决这个问题吗?有必要处理这个吗?或者,也许可以将等级视为树高的上限而不是确切的高度? 谢
我有两个类,A 和 B。A 是 B 的父类,我有一个函数接收指向 A 类型类的指针,检查它是否也是 B 类型,如果是将调用另一个函数,该函数接受一个指向类型 B 的类的指针。当函数调用另一个函数时,我
有没有办法让 valgrind 使用多个处理器? 我正在使用 valgrind 的 callgrind 进行一些瓶颈分析,并注意到我的应用程序中的资源使用行为与在 valgrind/callgrind
假设我们要使用 ReaderT [(a,b)]超过 Maybe monad,然后我们想在列表中进行查找。 现在,一个简单且不常见的方法是: 第一种可能性 find a = ReaderT (looku
我的代码似乎有问题。我需要说的是: if ( $('html').attr('lang').val() == 'fr-FR' ) { // do this } else { // do
根据this文章(2018 年 4 月)AKS 在可用性集中运行时能够跨故障域智能放置 Pod,但尚不考虑更新域。很快就会使用更新域将 Pod 放入 AKS 中吗? 最佳答案 当您设置集群时,它已经自
course | section | type comart2 : bsit201 : lec comart2 :
我正在开发自己的 SDK,而这又依赖于某些第 3 方 SDK。例如 - OkHttp。 我应该将 OkHttp 添加到我的 build.gradle 中,还是让我的 SDK 用户包含它?在这种情况下,
随着 Rust 越来越充实,我对它的兴趣开始激起。我喜欢它支持代数数据类型,尤其是那些匹配的事实,但是对其他功能习语有什么想法吗? 例如标准库中是否有标准过滤器/映射/归约函数的集合,更重要的是,您能
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 9 年前。 Improve
我一直在研究 PHP 中的对象。我见过的所有示例甚至在它们自己的对象上都使用了对象构造函数。 PHP 会强制您这样做吗?如果是,为什么? 例如: firstname = $firstname;
...比关联数组? 关联数组会占用更多内存吗? $arr = array(1, 1, 1); $arr[10] = 1; $arr[] = 1; // <- index is 11; does the
我是一名优秀的程序员,十分优秀!