首页 > web前端 > js教程 > 正文

《JavaScript DOM 编程艺术》读书笔记之DOM基础_javascript技巧

php中文网
发布: 2016-05-16 16:21:22
原创
1715人浏览过

DOM
      
      DOM:文档对象模型;

节点

       元素节点:DOM的原子是元素节点。

    之类的元素。元素可以包含其他的元素。没有被包含在其他元素里的唯一元素是元素

           文本节点:在XHTML文档里,文本节点总是被包含在元素节点的内部。

           属性节点:属性节点用来对元素做出更具体的描述。例如,几乎每个元素都有一个title属性,而我们可以利用这个属性对包含在元素里的东西作出准确的描述:

          

    Don't forget to buy this stuff.

    立即学习Java免费学习笔记(深入)”;

           在DOM中,title="a gentle reminder"是一个属性节点。

    CSS

         获取元素
          getElementById, getElementsByTagName, getElementsByClassName三种可以获取元素节点的方法。

          getElementsByTagName允许把一个通配符作为它的参数,而这意味着文档里的每个元素都将在这个函数所返回的数组里占有一席之地。通配符(“*”)必须在引号里,这是为了和乘法操作有所区别。

          还可以把getElementById和getElementsByTagName结合起来运用。如下所示:

    Brev AI
    Brev AI

    Brev.ai:搭载Suno AI V3.5技术的免费AI音乐生成器

    Brev AI 437
    查看详情 Brev AI

    复制代码 代码如下:

          var shopping = document.getElementById("purchase");
          var items = shopping.getElementsByTagName("*");

          这样就可以得到id属性值为purchase的元素包含着多少个元素。

          getElementsByClassName方法只有较新的浏览器才支持。为了弥补这一点,DOM脚本程序员需要使用已有的DOM方法来实现自己的getElementsByClassName。而多数情况下,他们的实现过程都与下面这个getElementsByClassName大致相似:

    复制代码 代码如下:

          function getElementsByClassName(node, classname){
            if(node.getElementsByClassName){
              return node.getElementsByClassName(classname);
            }else{
              var results = new Array();
              var elems = node.getElementsByTagName("*");
              for(var i=0;i             if(elems[i].className.indexOf(classname) != -1){
                  results[results.length] = elems[i];
                }
             }
             return results;
          }
       }

       这个getElementsByClassName函数接受两个参数,第一个node表示DOM树中的搜素起点,第二个classname就是要搜索的类名了。

    获取和设置属性

         getAttribute是一个函数,它只有一个参数——你打算查询的属性的名字:

    复制代码 代码如下:

         object.getAttribute(attribute)

         setAttribute()允许我们对属性节点的值做出修改。通过setAttribute对文档作出修改后,在通过浏览器的view source(查看源代码)选项去查看文档的源代码时看到的仍将是改变前的属性值,也就是说,setAttribute做出的修改不会反映在文档本身的源代码里。这种“表里不一”的现象源自DOM的工作模式:先加载文档的静态内容,再动态刷新,动态刷新不影响文档的静态内容。这正是DOM的真正威力:对页面内容进行刷新却不需要在浏览器里刷新页面。

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号