- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在为我的工作创建一个 Javascript 框架,支持最现代的浏览器(FF 4+、Chrome、Opera 11+、IE8+)。我在尝试扩展 prototype
时遇到了一些问题样式规则(假设 rule
是样式规则):
CSSStyleRule
对象,即使 String(rule) === "[object CSSStyleRule]"
. rule instanceof CSSRule
仍然是真的,但是 CSSRule.prototype
未定义。我知道获得正确原型(prototype)的唯一方法是 rule.__proto__
.parentStyleSheet
属性(property)。 "parentStyleSheet" in CSSStyleRule.prototype
始终为 false,我最好不想覆盖 native 实现,因为软编码实现并不十分便宜(至少,第一次运行时如此)。有可用的样式规则就足以让我继续,但是这两点是问题,因为我正在处理一个框架,该框架是在加载文档之前定义的,所以我无法添加 <style>
元素到 DOM。
所以,我要问的是:
我担心第一个问题的答案是“否”。
最佳答案
before the document is loaded, so I can't add elements to the DOM
如果你不能附加到 document.head 那么你可以做丑陋的 document.write('<link rel="stylesheet" ...
.然而 AFAIK 这不是问题,只要您附加到 document.head - 这是我们在我们的框架中所做的:
<script>
(function(){
var s='blueskin';
var link=document.createElement('link');
var h=document.getElementsByTagName('head')[0];
link.type='text/css';
link.rel='stylesheet';
link.href='/skins/'+s+'.css';
h&&h.appendChild(link);
})();
</script>
为外部 css 文件动态添加样式表:
var link = document.createElement('link');
link.setAttribute('rel', 'stylesheet');
link.type = 'text/css';
link.href = 'http://example.com/stylesheet.css';
document.head.appendChild(link);
如果您将 CSS 作为字符串,则可以添加 style
元素动态使用(这适用于我使用的所有浏览器,我认为这适用于 Opera,但我最近没有尝试过):
var styleElement = document.createElement('style');
styleElement.type = 'text/css';
styleElement.rel = 'stylesheet';
setCss(styleElement, css);
document.head.appendChild(styleElement);
function setCss(styleElement, css) {
if (styleElement.styleSheet) { // IE
styleElement.styleSheet.cssText = css || '';
} else {
var firstChild = styleElement.firstChild;
firstChild && styleElement.removeChild(firstChild);
var textnode = document.createTextNode(css || '');
styleElement.appendChild(textnode);
}
}
cssFx项目动态修复 <link rel="stylesheet"
的 CSS歌剧元素,如果你想做一些更复杂的事情。
如果您不想添加到 document.head,那么您也可以将子样式表添加到现有样式表(相当于 @import
),尽管我没有相应的代码片段。
最后,如果样式表需要进入正文,那么您将不得不使用 onload 或 jQuery $(myReadyFn);事件处理程序。
关于javascript - 获取 <style> 原型(prototype),CSSStyleRule/CSSRule 乱七八糟,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10653782/
前言: 一直是想知道一条SQL语句是怎么被执行的,它执行的顺序是怎样的,然后查看总结各方资料,就有了下面这一篇博文了。 本文将从MySQL总体架构--->查询执行流程--->语句执
哪个更好用或者更方便: ... 或 ... 最佳答案 你真的需要类型属性吗?如果您使用的是 HTML5,则不会。否则,是的。 HTML 4.01 和 XHTML 1.0 指定了 type属性是必需的,
哪个更好用或者更方便: ... 或 ... 最佳答案 你真的需要类型属性吗?如果您使用的是 HTML5,则不会。否则,是的。 HTML 4.01 和 XHTML 1.0 指定了 type属性是必需的,
我在 unix shell 脚本中遇到了一个问题。让我用一个非常简单的例子来问你。 假设,我正在获取用户输入并比较两个数字。 echo "Enter the first number" read a
是否可以在中制作文本?上标?如果是,怎么办? Meraki Baked Goods (Post 7: Dad's 50th) 最佳答案 以下似乎对我有用: Dad's 50ᵗʰ
我有一个转发器控件,其中 部分没有出现。 “Display”存储的代码设置如下: item.Display = " AudioPlayer.embed('ffcedea7-4822-465f-
在许多 .resx 文件中,我遇到了这样的事情: OurLabel 我的问题是:为什么属性name在许多情况下 - 但并非总是如此 - 从 >> 开始? 最佳答案 您在 Winfo
我正在尝试将代码添加到脚本中,但它不起作用 var script= document.createElement('script'); script.type= 'text/javas
我想编写正则表达式来读取 block 内的数据在 HTML 中。作为脚本,我认为空白具有灵 active 。为了使我的正则表达式模式健壮,我必须预测不同数量的空白。也许有比在我的模式中放置许多空白匹
基本上,我讨厌必须更改标题代码以及位于 中的页面标题。 header 中的标签....我可以使用 JavaScript 或 HTML 来自动设置某个 标题中的内容是否等于页面标题? 最佳答案 是的,
我可以使用以下代码提取所有标签。但是,我不知道如何在 之间查看内部。和标签。特别是,假设我只想要这一部分(中间还有更多内容,但我对此不感兴趣): var quoteData
有什么方法可以覆盖无法直接编辑的页面标题,只能在页眉中添加 Javascript? 我不能直接编辑的行是: Title of the page 我能想到的解决这个问题的唯一方法是在我可以通过我的门户后
我正在尝试在 fancybox 的内容方法中加载 javascript 内容。 $('#streaminput').on("click", function() { $('#streaminpu
我试图在 2 小时内解决这个问题,但运气不佳,也许这不是那么技术性,但我需要帮助! 我有一个 AJAX 脚本,需要将 GET 请求发送到同一页面上的 php 脚本。PHP 脚本这样终止 i
如何创建表单来删除标签并删除标签之间的内容或脚本。请任何人为我制作一份表格(我已经问过这个问题,但没有找到任何有用的答案。) 像这样的形式:(此形式仅删除标签,不删除text标签之间的脚本) //
我现在已经为此苦苦挣扎太久了。 我想做的只是简单地堆叠后续内容,就像您将一张 1 列 3 行的表格一样。我试图放弃旧的 HTML 和 CSS 方法,转而采用首选的 HTML5 页面结构方法。 像这样.
我正在尝试为 my chat box 创建通知,当有人向您发送新消息时,会在“谈话”标题旁边看到。我尝试过多种方法,但从来没有成功过。 a busy cat http://goawaymom.com/
我最初并不期望需要调用除 Iframe 之外的任何内容,但显然我错了。这是我的代码,您可以看到为什么它破坏了脚本中的脚本-/脚本有什么方法可以解决这个问题? $ad_blocks = arra
我希望能够在正在播放的视频之上使用全屏文本区域。我以为 position: fixed;顶部:0;可能有效,但没有。 HTML CSS * { box-sizing: border-box;
我找到了how to load external JS file into moodle?但这并不能解决我的问题。 我必须加载一个外部 JS 文件,因为它是 VOD 服务的播放器。 必须在 中调用它
我是一名优秀的程序员,十分优秀!