JavaScript 之 DOM

DOM

概念

  • DOM:Document Object Model 文档对象模型。
  • DOM作用:操作页面中的元素。
  • 顶级对象是document 就是指HTML或者XML文件。
  • HTML侧重于展示数据,XML侧重于存储数据,XHTML写的是HTML代码,遵循的是XML 的规范。
  • 每一个HTML文件都可以看成是一个文档对象,里面所有的标签的层次关系都可以看成是一个树形结构图,树状图。
  • 页面中所有的内容都是节点:标签节点,属性节点,文本节点。IE8中会忽略空白节点
  • 节点属性
    • nodeType 如果是标签,值为1;如果是属性,值为2;如果是文本,值为3
    • nodeName 如果是标签,值为大写标签名字;如果是属性,值为小写属性名字;如果是文本,值为#text
    • nodeValue 如果是标签,值为 null ;如果是属性,值为属性值;如果是文本,值为文本内容
  • 页面中的标签,标签就是元素,元素就可以看成是对象,标签也是节点。
    • 节点比元素大。
    • 根元素:页面中最外边的标签
    • 文档元素:文档中的第一个元素,HTML文档元素就是< html>

绑定和解绑

  • 第一种写法
    • 对象.on+"事件名字"=事件处理函数
    • 对象.on+"事件名字"=null
  • 第二种写法
    • 对象.addEventListener("事件名字",命名函数,false);
    • 对象.revemoEventListener("事件名字",命名函数的名字,false);

事件冒泡

  • 元素A中嵌套了另一个元素B,里面元素B和外面元素A注册了相同的事件,如果里面元素B的事件触发了,外面的元素A的该事件也会自动的触发。
  • 阻止事件冒泡的两种方法 window.event.cancelBubble=true 或者是 e.stopPropagation();

事件的三个阶段

  • 事件捕获阶段,事件目标阶段,事件冒泡阶段

  • 事件阶段有一个属性,这个属性是需要通过事件参数对象.eventPhase来获取的

  • 属性的值是:1->捕获阶段2->目标阶段3->冒泡阶段

  • e.type获取的是当前触发该事件的事件类型

    <script>
      var objs=[my$("dv1"),my$("dv2"),my$("dv3")];
      objs.forEach(function(element){
          element.addEventListener("click",function(e){
              console.log(this.id+"==="+e.eventPhase+"==="+e.type);
          },false);
      });
    </script>
    

    false值由内向外,一般采用false

    dv3===2===click

    dv2===3===click

    dv1===3===click

    <script>
      var objs=[my$("dv1"),my$("dv2"),my$("dv3")];
      objs.forEach(function(element){
          element.addEventListener("click",function(e){
              console.log(this.id+"==="+e.eventPhase+"==="+e.type);
          },true);
      });
    </script>
    

    true值由外向内

    dv1===1===click

    dv2===1===click

    dv3===2===click

DOM级别

  • DOM0 初级阶段
  • DOM1 规定了节点的类型Node,一般使用DOM1
  • DOM2 新增了一些方法,但是很多浏览器并不支持
  • DOM3 大多数浏览器都没有支持

全局变量和隐式全局变量

  • 全局变量不会被删除,隐式全局变量会被删除
<script>
  var num=10;//全局变量
  number=20;//隐式全局变量
  delete num;//删除全局变量
  delete number;//删除隐式全局变量
  console.log(typeof num);//number
  console.log(typeof number);//undefined
</script>

innerText和innerHTML

  • 设置文本内容的时候,用两个都一样
  • 设置标签内容的时候
    • innerText设置标签内容,显示的是标签+文本,标签实际上是转义出来了
    • innerHTML设置标签内容,显示的是效果
  • 如果想要设置文本,用谁都可以,如果想要有标签效果,用innerHTML
  • 获取标签中的文本内容,使用innerText和innerHTML都可以,如果获取的是元素中的标签和文本内容,应该使用innerHTML

innerText和textContent

  • innerText:谷歌支持,低版本火狐不支持,高版本火狐支持,IE8支持
  • textContent:谷歌支持,火狐支持,IE8不支持
  • 浏览器不支持某属性时,该属性的类型是undefined

className

  • html标签中的class属性,在js 中是关键字,不能直接使用。所以, 对象.class="值"; 这种写法是错误的。应该这么写:对象.className="值";
  • 对象.style.属性名="值"; div.style.backgroundColor="red";
  • 对象.className="值"; div.className="cls";

自定义属性

  • 获取自定义属性的值 对象.getAttribute(“属性的名字”); 返回值是该属性的值
  • 设置自定义属性的值 对象.setAttribute(“属性的名字”,”值”);
  • removeAttribute,getAttribute,setAttribute三个方法不仅可以操作元素的自定义属性及值,还可以操作元素的自带属性

隐藏方式

<script>
  zy$("btn").onclick=function(){
    zy$("div").style.display="none";//不占位置      
    zy$("div").style.visibility="hidden";//占位置
    zy$("div").style.opacity=0;//占位置
    zy$("div").style.width=0;//占位置
    zy$("div").style.height=0;
  }
</script>

设置样式

  • 如果样式的属性是在style属性中设置的,是可以直接获取的
  • 如果样式的属性是在style标签中设置的,不能直接获取

获取节点元素12个

<script>
 console.log(zy$("uu").childNodes);
 console.log(zy$("uu").children);//推荐使用
 console.log(zy$("uu").parentNode);//推荐使用
 console.log(zy$("uu").parentElement);
 console.log(zy$("uu").firstChild);
 console.log(zy$("uu").firstElementChild);
 console.log(zy$("uu").lastChild);
 console.log(zy$("uu").lastElementChild);
 console.log(zy$("uu").previousSibling);
 console.log(zy$("uu").previousElementSibling);
 console.log(zy$("uu").nextSibling);
 console.log(zy$("uu").nextElementSibling);
</script>

创建元素的两种方式

  • 第一种 对象.innerHTML=”标签代码及内容”
  • 第二种 document.creatElement

三大系列

offset系列

  • offsetLeft:元素相对左边的横坐标
  • offsetTop:元素相对上面的纵坐标
  • offsetWidth:元素的宽度,有边框
  • offsetHeight:元素的高度,有边框
  • offset系列获取的值都是数字类型
  • offsetWidth(offsetHeight)获取的元素本身的宽(高)+元素边框的宽(高)
  • 如果父级元素脱离文档流,子级元素此时的offsetLeft获取的是相对父级元素的pading+自己的margin
  • 如果元素自己脱离文档流,此时的offsetLeft获取的事自己的left+自己的margin

scroll系列

  • scrollLeft:向左卷曲出去的横坐标
  • scrollTop:向上卷曲出去的纵坐标
  • scrollWidth:内容实际的宽度,没有内容就是元素的宽度,没有边框
  • scrollHeight:内容实际的高度,没有内容就是元素的高度,没有边框

client系列

  • clientX:可视区域的横坐标
  • clientY:可视区域的纵坐标
  • clientWidth:可视区域的宽
  • clientHeight:可视区域的高
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,496评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,407评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,632评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,180评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,198评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,165评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,052评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,910评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,324评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,542评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,711评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,424评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,017评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,668评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,823评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,722评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,611评论 2 353

推荐阅读更多精彩内容