醉啊罪 2021-05-19 18:00 采纳率: 0%
浏览 740

为什么querySelector不能及时获取元素

为什么使用querySelector获取元素时,使用class不能及时获取到元素,但是id可以

<script>
        window.addEventListener('load',function () {
          // 1. 获取元素
          var cloud = document.querySelector('.cloud');
          var c_nav = document.querySelector('.c_nav');
          var lis = c_nav.querySelectorAll('li');
    </script>

 调试如下:

1.不能获取到c_nav元素

2.但是querySelector报错后,可以获取到。

使用id获取c_nav时却可以直接获取到

<script>
        window.addEventListener('load',function () {
          // 1. 获取元素
          var cloud = document.querySelector('.cloud');
          var c_nav = document.querySelector('#c_nav');
          var lis = c_nav.querySelectorAll('li');
</script>

 调试如下:

想请问一下是为什么?

  • 写回答

1条回答 默认 最新

  • 斯洛文尼亚旅游 2021-05-19 18:06
    关注

    你的dom怎么生成的,而且加了样式c_nav了没有?

    不是说放到load事件中所有dom都能获取的,如ajax异步加载的可能ajax未返回就执行load事件了。获取ajax动态返回的需要在ajax回调中获取

    评论

报告相同问题?

悬赏问题

  • ¥15 WPF动态创建页面内容
  • ¥15 如何对TBSS的结果进行统计学的分析已完成置换检验,如何在最终的TBSS输出结果提取除具体值及如何做进一步相关性分析
  • ¥15 SQL数据库操作问题
  • ¥100 关于lm339比较电路出现的问题
  • ¥15 Matlab安装yalmip和cplex功能安装失败
  • ¥15 加装宝马安卓中控改变开机画面
  • ¥15 STK安装问题问问大家,这种情况应该怎么办
  • ¥15 关于罗技鼠标宏lua文件的问题
  • ¥15 halcon ocr mlp 识别问题
  • ¥15 已知曲线满足正余弦函数,根据其峰值,还原出整条曲线