- 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/
我在休息服务中有以下方法: @POST @Path("/create") @ResponseStatus(HttpStatus.CREATED) @Consumes(M
这个问题不太可能对 future 的访客有帮助;它只与一个小的地理区域、一个特定的时刻或一个非常狭窄的情况相关,通常不适用于互联网的全局受众。如需帮助使这个问题更广泛地适用,visit the hel
我有这样的弹出框: Speelland And here's some amazing content. It's very engaging. Right? Meer
我正在开发一个 firefox 插件,我正在收听这样的 http 响应: var observerService = Components.classes["@mozilla.org/observer
我正在使用 jqtouch 制作一个移动网站。我还在网站中实现了图库图像 slider ,但是当图库放在我需要的位置时(在 之间,图像不会显示。 修补了几个小时后,删除了 display: none
为了在 iPad 上的 Safari 上显示视差效果,我采用了以下 CSS 规则: body:after { content: ""; position: fixed; top
我想在通过 excel VBA 创建的电子邮件正文中插入一个链接。链接每天都在变化,所以我把它的值放在单元格 B4 中。但是,我找不到正确的方法来发送带有该链接的电子邮件。 这是我正在使用的代码: P
我正在尝试使用具有非常大主体的 Postman 执行 POST 请求。只有一个 JSON 字段非常大,我想知道是否可以从 Postman 的文件中加载该字段? { "field1": {
这个问题是针对 SoapUI 5.2.1 社区版的: 我有一个包含变量的 JSON 主体的 POST 请求。 我总是能够通过单击“原始”选项卡以查看请求进行或将发送到服务器来验证这些参数是否采用正确的
我有这个按钮,单击该按钮会打开 Outlook,其中包含我提供的详细信息。我还有一个 TEXTAREA,其中包含某些文本。我正在寻找一种方法让此文本出现在我的 Outlook 正文中。这可以做到吗?请
我知道错误消息是不言自明的,我们无法多次读取消息正文。这里我使用AOP(面向方面编程)来进行审计日志。 [AuditServiceMethod(AttributePriority = 0)] [F
我在 grails 3.3.3 中编写自定义验证器(命令)时遇到了一些问题。具体来说,我正在尝试验证其正文由项目列表组成的 POST 请求。这就是我所拥有的... 命令: class VoteComm
这个问题在这里已经有了答案: json.Marshal(struct) returns "{}" (3 个回答) JSON and dealing with unexported fields (3
我想清理很多邮件的 HTML 正文,它们有点脏(取自 Gmail 发送的电子邮件):有很多嵌套 ,不需要的字体更改等我想清理它并只保留 , , , , , 仅此而已(可能还有 或一些 ,
我正在使用 Accordion 功能在我的模块中添加端口详细信息。我只想在水平方向上显示正文内容。请看下面的 fiddle 。 html, body { background-color:#e
我的 HTML 正文中有这个: loaded y&EACUTE;t. 使用 JavaScript 我有这个: $( document ).ready(function() { document.bod
我对图表有很大的疑问。我试图在谷歌图表中显示一些 json 值,但我总是会出错。从 JSON 正文中,我只需要图表上个月的“全部购买”和“日期”。我见过的所有例子,他们已经有了一个静态的自定义 Jso
我的应用程序的功能之一涉及用户填写三个单独的文本字段(预订名称、客人和日期),然后使用文本编辑器通过短信发送这些字段中的文本。我无法将这些 View 中的文本放入正文中。这是我的代码: - (IBAc
我正在开发一个 HTA,它应该对 onunload 事件进行一些最终修改。该事件似乎没有被触发。 该事件是否仍受支持?是否有 IE 事件可以知道页面何时关闭? 我检查了一下(JavaScript bo
我正在尝试将以下图像添加为网站内容的背景: http://webbos.co/vibration/wp-content/themes/vibration-child-theme/images/back
我是一名优秀的程序员,十分优秀!