首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何向document.getElementById添加延迟

如何向document.getElementById添加延迟
EN

Stack Overflow用户
提问于 2018-06-22 03:55:54
回答 2查看 1K关注 0票数 -4

我有这个:

我正在尝试加载这段js代码,value.id对应于加载页面后检测到的一个元素。但实际上,这段代码是在元素加载之前运行的,而im出现了这个错误:

无法读取null的属性“nodeType”

我想在document.getElementById(value.id)上添加像delay这样的东西

我试过了,但什么也没做:

代码语言:javascript
复制
    const area = setTimeout(document.getElementById(value.id), 4000);
    Count.on(area, counter => {
    ...

和:

代码语言:javascript
复制
function setDelay() {
  document.getElementById(value.id);
}
setTimeout(setDelay, 4000);
const area = setDelay
Count.on(area, counter => {
...

两者都给出了相同的错误,你知道吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-06-22 04:21:35

感谢所有人,我用这样的方式解决了这个问题:

代码语言:javascript
复制
$(document).ready(function(){
// your code
});
票数 0
EN

Stack Overflow用户

发布于 2018-06-22 04:02:46

您可以将代码放在一个函数中,并将其称为setDelay函数

代码语言:javascript
复制
function setDelay() {
    const area = document.getElementById(value.id);
    Count.on(area, counter => {
    ...
}
setTimeout(setDelay, 4000);

setTimeout不会向调用者返回任何内容。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50976575

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档