因此,我正在为jquery/javascript制作一个幻灯片插件,目前我正在尝试创建一个具有类名“幻灯片”的所有元素的列表。为此,我在javascript模块的顶部定义了一个全局变量,该变量调用一个函数,该函数(应该)返回类名为“幻灯片”的元素列表。尽管出于某种原因,它返回一个空数组,函数内部和外部,尽管显然有一个名为“幻灯片”的div,但是除了之外,当我在单独的函数中打印模块顶部定义的全局变量时(不是前面提到的),它可以正常工作。
以下是html:
<head>
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
    <script type="text/javascript" src="slideshow.js"></script>
</head>
<body>
    <div class="slideshow"></div>
</body>这里是javascript/jquery模块"slideshow.js":
var slideshows = getSlideshows();
function getSlideshows() {
    var slideshows = document.getElementsByClassName("slideshow");
    console.log(slideshows); // prints []
    return slideshows;
}
console.log(slideshows); // prints []
$(function test1() {
    console.log(slideshows); // prints [div.slideshow], which is correct.
});知道它为什么要打印不同的价值吗?
谢谢!
发布于 2015-08-06 23:17:20
您有两个选项,要么可以将脚本放在页脚中,要么包装脚本,并在文档准备好时告诉它启动:
$( document ).ready(function() {
    var slideshows = getSlideshows();
    function getSlideshows() {
      var slideshows = document.getElementsByClassName("slideshow");
      console.log(slideshows);
      return slideshows;
    }
    console.log(slideshows);
}否则,您的脚本将在它试图引用的html存在之前触发。
发布于 2015-08-06 23:18:33
<head>部分中的脚本在解析页面主体之前执行,因此当您在前两次显示时,getElementsByClassName返回的HTMLCollection是空的。
文档完全加载后,test1就会运行,元素就会显示出来。这是因为 is live:随着DOM的变化,它会自动更新。
https://stackoverflow.com/questions/31867061
复制相似问题