- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在学习用 Javascript 编程。我在这里创建了一个 jsfiddle - http://jsfiddle.net/vvMRX/1/
function turnRed(node,f){
setTimeout(f,2000,[node]);
}
(function pageLoaded(){
turnRed(document.body,function(node){
alert(node);node.style.backgroundColor = '#ff0000';
});
})();
我正在尝试对函数使用 setTimeout
调用来更改正文背景颜色。我将 document.body
作为节点传递。在回调中,我更改了 node.style.backgroundColor
但它不起作用。有趣的是,直接使用 document.body.style.backgroundColor
就可以了。如果我放置一个 alert(node)
,它会正确地将其识别为 html bodyelement
。
我在这里错过了什么?
感谢回复。
最佳答案
这是在您的 JS 中抛出的以下错误:
Uncaught TypeError: Cannot set property 'backgroundColor' of undefined
这是因为在您的 setTimeout
中,你正在传递 node
在一个数组中。但是,在您的回调中,您直接访问了该节点。解决此问题的两种方法是:
更新您的回调以访问 node
在 array
内.
(function pageLoaded(){
turnRed( document.body, function(node){
alert(node);
// Updated code below
node[0].style.backgroundColor = '#ff0000';
});
})();
另一种方法是更新您的 setTimeout 并直接传递节点。
function turnRed(node,f){
setTimeout(f,2000,node);
}
这是一个更新的 fiddle :http://jsfiddle.net/vvMRX/3/
您提到使用 document.body.style.backgroundColor
工作 - 这是有道理的 - 自 document.body
将指向 element
包含内容。对于大多数页面,这几乎总是 <body>
元素。但是,对于 frameset
文档,这将返回外框。 ( w3.org reference )
最后,关于 alert
- 这是怎么回事,对吧?你打电话alert(node)
, 并显示 [object HTMLBodyElement]
,这意味着您传递了正确的 element
, 正确的? (至少,我也是这么想的!)
实际发生的是 alert
正在提醒您数组的值。
这是一个 fiddle 演示:http://jsfiddle.net/4Lf3J/
您应该看到三个警报。
在第一个alert
,我已经更新了原始警报以调用 node.constructor
. Object.prototype.constructor
将返回对创建实例的对象的引用 ( MDN reference )。
在这种情况下,我们会看到
function Array() { [native code] }
这有望再次强化您正在通过 array
的想法。 .
第二个alert
实际上是在调用 alert(document.body.constructor)
,这是我们最初期望看到的。在这种情况下,我们看到:
function HTMLBodyElement() { [native code] }
最后,第三个 alert
显示值 1,2,3,4,5
,这只是一个具有这些值的简单数组的警报(再次强调警报将警报数组的值的想法 - 这就是您认为警报是正确的原因)。
希望这对您继续学习 JavaScript 有所帮助!
关于javascript - 无法使用 javascript 回调更改正文背景颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23100632/
我正在阅读 java swing,但在理解它时遇到问题。 Color 是一个类吗? Color[] col= {Color.RED,Color.BLUE}; 这在java中是什么意思? 最佳答案 Is
我正在研究用 python 编写的 pacman 程序。其中一个模块是处理吃 bean 游戏的图形表示。这当然是一些主机颜色。列表如下: GHOST_COLORS = [] ## establishe
本网站:http://pamplonaenglishteacher.com 源代码在这里:https://github.com/Yorkshireman/pamplona_english_teache
我最近将我的手机更新为 Android Marshmallow 并在其上运行了我现有的应用程序,但注意到颜色行为有所不同:将更改应用到 View (可绘制)的背景时,共享相同背景的所有 View (引
所有 X11/w3c 颜色代码在 Android XML 资源文件格式中是什么样的? I know this looks a tad ridiculous as a question, but giv
试图让 ffmpeg 创建音频波形,同时能够控制图像大小、颜色和幅度。我已经尝试过这个(以及许多变体),但它只是返回无与伦比的 "。 ffmpeg -i input -filter_complex "
我很好奇你是否有一些关于 R 中颜色酿造的技巧,对于许多独特的颜色,以某种方式使图表仍然好看。 我需要大量独特的颜色(至少 24 种,可能需要更多,~50 种)用于堆叠区域图(所以不是热图,渐变色不起
我看到的许多 WPF 示例和示例似乎都有硬编码的颜色。这些指南 - http://msdn.microsoft.com/en-us/library/aa350483.aspx建议不要硬编码颜色。在构建
我想更改文件夹的默认蓝色 如何设置? 最佳答案 :hi Directory guifg=#FF0000 ctermfg=red 关于Vim NERDTree 颜色,我们在Stack Overflow上
是否有关于如何将任意字符串哈希为 RGB 颜色值的最佳实践?或者更一般地说:3 个字节。 你问:我什么时候需要这个?这对我来说并不重要,但想象一下任何 GitHub 上的那些管图 network pa
我正在尝试将默认颜色设置为自定义窗口小部件。 这是有问题的代码。 class ReusableCard extends StatelessWidget { ReusableCard({this.
import javax.swing.*; import javax.swing.table.DefaultTableCellRenderer; import javax.swing.table.Ta
我有一个 less 文件来定义一堆颜色/颜色。每个类名都包含相关颜色的名称,例如 .colourOrange{..} 或 .colourBorderOrange{..} 或 navLeftButtOr
我有一个RelativeLayout,我需要一个黑色背景和一个位于其中间的小图像。我使用了这段代码: 其中@drawable/bottom_box_back是: 这样我就可以将图像居中了。但背
我需要设置 浅色 的 JPanel 背景,只是为了不覆盖文本(粗体黑色)。 此刻我有这个: import java.util.Random; .... private Random random =
我正在尝试制作一个自定义文本编辑器,可以更改特定键入单词的字体和颜色。如何更改使用光标突出显示的文本的字体和/或颜色? 我还没有尝试过突出显示部分。我尝试获取整个 hEdit(HWND) 区域并更改字
我想改变我整个应用程序的颜色。 在我的 AndroidManfiest.xml 中,我有正确的代码: 在 values 文件夹中,我有 app_theme.xml: @style/MyAc
是否可以使用 android 数据绑定(bind)从 xml 中引用颜色? 这很好用: android:textColor="@{inputValue == null ? 0xFFFBC02D : 0
有没有办法在 Android 应用程序中设置“空心”颜色? 我的意思是我想要一个带有某种背景的框,而文本实际上会导致背景透明。换句话说,如果整个 View 在蓝色背景上,文本将是蓝色的,如果它是红色的
我用CGContextStrokePath画在白色背景图片中的一条直线上,描边颜色为红色,alpha为1.0画线后,为什么点不是(255, 0, 0),而是(255, 96, 96)为什么不是纯红色?
我是一名优秀的程序员,十分优秀!