zoukankan      html  css  js  c++  java
  • DOM+position:relative+缓冲运动

    一、nodeType节点类型

      nodeType==3  ->文本节点

      nodeType==1  ->元素节点

    1 forvar i=0;i<oUl.childNodes.length;i++ ){  //此处的oUl是 var oUl = document.getElementById('ul');获取ul标签的保存值
    2 //alert(oUl.childNodes[i].nodeType)不同版本浏览器观看返回值,就清楚返回1和3的区别
    3 if(oUl.childNodes[i].nodeType==1){
    4 oUl.childNodes[i].style.background='red';
    5 }
    6 }

     用childNodes的话,倒不如用children。

    alert(oUl.children.length);

    二、父节点parentNode的应用

     1 for(var i=0;i<aA.length;i++){         //少一部分代码,有点懒打上去
     2 aA[i].onclick = function(){
     3  this.parentNode.style.display= 'none';   //这里的父节点指li,所以是获取a标签
     4 };
     5 
     6 }
     7 };
     8 <head>   //html代码开始
     9 <body>
    10  <ul>
    11 <li>dsfasdfsfasd<a>隐藏</a></li>
    12 <li>dsfasdfsfasd<a>隐藏</a></li>
    13 <li>dsfasdfsfasd<a>隐藏</a></li>
    14 <li>dsfasdfsfasd<a>隐藏</a></li>
    15 </ul>

    三、position:relative

    先定义两个div样式

    1 #div1 { width:200px;height:200px;background:#CCC;}
    2 #div2 {width:100px;height:100px;background:red;position:absolute;}//先设置div2 绝对定位
    <div id='div1'>
    <div id='div2'></div>   //div1包含div2
    </div>

    div2绝对定位时,是如图这样子的

    但是更改div1的位置的时候,div1移动,但是div2还是好好保留在原来的位置。如果想让div2跟随div1移动,则要给div1添加了相对定位,才能让div2相对定位

    #div1 { width:200px;height:200px;background:#CCC;position:relative;left:50px;}  
    #div2 {width:100px;height:100px;background:red;position:absolute;left:50px;top:50px;}

     

    我修改了left值,让div1移动,再添加了position:relative 相对定位,让div2跟对div1移动。

     到这里,position:relative相对定位就清晰了。

    四、DOM节点

      首尾节点:(有兼容性问题)

      firstChild、firstElementChild

      lastChild、lastElementChild

        兄弟节点:(有兼容性问题)

      nextSibling、nextElementSibling

      previousSibling、previousElementSibling

    兼容性问题代码如下

    window.onload = function(){
    var oUl = document.getElementById('ul1');
    //IE6 7 8
    //oUl.firstChild.style.background = 'red'; 此行代码在高版本运行不起来
    
    //高级浏览器
    oUl.firstElementChild.style.background = 'red';    //此行代码在较低级浏览器运行不起来
    
    
    }

    所谓兼容性问题。,如firstChild在高版本浏览器中,它获取的是ul后面到li之间的空白部分。而低版本却没有这个问题。

    所以,这里解决兼容性问题办法就是用if判断(ajax的兼容性问题也是用if判断)

    1 if(oUl.firstElementChild){
    2 oUl.firstElementChild.style.background = 'red';
    3 }else{
    4 
    5 oUl.firstChild.style.backGround = 'red';
    6 }

    五、操纵元素属性

      DOM方式操作元素属性

      获取:getAttribute(名称)

      设置:setAttribute(名称,值)

      删除:removeAttribute(名称)

      用id选元素比较精准,可是当元素多的情况时候,一个一个去加就特别麻烦,所以推荐className属性操作

      用className选择元素

      如何用className选择元素

      1、选出所有元素

      2、通过className条件筛选

      3、封装函数

      

    var oUl = document.getElementById('ul1');
    var aLi = oUl.getElmentsByTagName('li');  //取标签
    
    for(var i = 0;i<aLi.length;i++){
    if(aLi[i].className=='box'){
    aLi[i].style.background='red';   //设置背景颜色
    }
    
    }
    };
    </script>
    </head>
    <body>
    <ul id='ul1'>
    <li  class="box"></li>  //li的class属性值为box
    <li class="box"></li>
    <li></li>
    <li></li>
    <li class="box"></li>
    </ul>
    </body>

    通过className选择元素,那么接下来就是封装函数方便我们使用

     1 function getByClass(oParent,sClass)
     2 {
     3 var aResult=[];
     4 var aEle = oParent.getElementsByTagName('*');//采用通配符获取所有的标签
     5 for( var i = 0;i<aEle.length;i++){
     6 if(aEle[i].className==sClass){
     7 aResult.push(aEle[i]);
     8 }
     9 }    
    10 
    11 return aResult;//获取对应的数组后,在遍历长度,再做对应的修改
    12 
    13 }

    接下来就是应用这个封装函数

    1 window.onload = function(){
    2 var oUl = document.getElementById('ul1');
    3 var aBox = getByClass(oUl,'box');    
    4 for(var i = 0;i<aBox.length;i++){
    5 aBox[i].style.background='red';
    6 }
    7 };

    六、创建、插入和删除元素

      创建DOM元素

      createElement(标签名)  创建一个节点

      appendChild(节点) 追加一个节点

       例子:为ul插入li

      插入元素

      insertBefore(节点,原有节点) 在以有的元素前插入

      例子:倒序插入li

      删除DOM元素

      removeChild(节点) 删除一个节点

      例子:删除li

       

     1 //appendChild的应用
     2 window.onload = function(){
     3 var oBtn = document.getElementById('btn1');
     4 var oUl = document.getElementById('ul1');
     5 var oTxt = document.getElementById('txt1');
     6 
     7 oBtn.onclick = function(){
     8 var oLi = document.createElement('li');
     9 oLi.innerHTML = oTxt.value;
    10 //父级.appendChild(子节点);
    11 oUl.appendChild(oLi);
    12 }
    13 };
    14 </script>
    15 </head>
    16 <body>
    17 <input id='txt1' type='text'>
    18 <input id='btn1' type='button' value='创建li'>
    19 </body>
    1 //往前面插入
    2 var oLi = document.createElement('li');
    3 var aLi = oUl.getElementsByTagName('li');//前提是已经有li的存在
    4 oLi.innerHTML=oTxt.value;
    5 oUl.insertBefore(oLi,aLi[i]);

    如果往前面插入li时,没有已存在的li,你说会怎样? 所以,我们要加个判断,所以下面是改进代码

    var oLi = document.createElment('li');
    var aLi = oUl.getElmentsByTagName('li');
    oLi.innerHTML = oTxt.value;
    if(aLi.length>0){
    oUl.insertBefore(oLi,aLi[i]);
    }else{
    oUl.appendChild(oLi);
    }

    下面是remove删除的例子

     1 window.onload = function(){
     2 var aA = document.getElementByTagName('a');
     3 var oUl = document.getElementById('ul1');
     4 for(var i=0;i<aA.length;i++){
     5 aA[i].onclick  = function(){
     6 oUl.removeChild(this.parentNode);
     7 }
     8 }
     9 };
    10 </script>
    11 </head>
    12 <body>
    13 <ul id='ul1'>
    14 <li>dasda<a href="javascript:">删除</a></li>
    15 <li>dasda<a href="javascript:">删除</a></li>
    16 <li>dasda<a href="javascript:">删除</a></li>
    View Code

    七、文档碎片

      文档碎片可以提高DOM操作性能(理论上)

      文档碎片原理

      document.createDocumentFragment()

      

    1 window.onload=function(){
    2 var oUl = document.getElementById('ul1');
    3 var oFrag = document.createDocumentFragment();
    4 for(var i =0;i<10000;i++){
    5 var oLi = createElement('li');
    6 oFrag.appendChild(oLi);
    7 }
    8 oUl.appendChild(oFrag);
    9 }

    在这个代码里面,其实加document.createDocumentFragment和不加效果差不多的,一般都是操作DOM几十条数据。一般很少1万条数据。在不同浏览器中,不加document.createDocumentFragment,IE浏览器会先描绘好后再加载,所以,会卡住几秒才会显示出来,其它浏览器就会好一点,比较快很多。在document.createDocumentFragment中,将创建好的li节点先保存在document.createDocumentFragment中,然后再将这个document.createDocumentFragment所保存的数据添加到oUl里。这样子性能会更快点。

    八、DOM高级应用-表格添加。

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>无标题文档</title>
    </head>
    
    <script>
    window.onload = function(){
        var oTa = document.getElementById('Tabe');
        var oNa = document.getElementById('txt1');
        var oAg = document.getElementById('txt2');
        var oBtn= document.getElementById('btn');
        var oid = oTa.tBodies[0].rows.length;
        var aAa = oTa.getElementsByTagName('a');
        
        
        
        btn.onclick = function(){
            
            var oTr = document.createElement('tr');
            var oTd = document.createElement('td');
            oTd.innerHTML = oid++;
            oTr.appendChild(oTd);
            
            var oTd = document.createElement('td');
            oTd.innerHTML = oNa.value;
            oTr.appendChild(oTd);
            
            var oTd = document.createElement('td');
            oTd.innerHTML = oAg.value;
            oTr.appendChild(oTd);
            
            var oTd = document.createElement('td');
            oTd.innerHTML = "<a href='javascript::'> 删除</a>";
            oTr.appendChild(oTd);
            
            
            
            oTa.appendChild(oTr);
            
            
            };
            
            
            
        
        };
    
    
    </script>
    <body>
    <input type=text id='txt1'><br>
    <input type=text id='txt2'><br>
    <input type=button id='btn' value="提交">
    
    <table border=1 id='Tabe'>
    <thead><td>序号</td><td>姓名</td><td>年龄</td></thead>
    <tbody>
    
    
    </tbody>
    
    
    </table>
    
    
    </body>
    </html>
    View Code

    效果图

    九、缓冲运动

    <title>缓冲运动</title>
    </head>
    <style>
    #div1{
        100px; height:100px; background:red; position:absolute; left:0px;top:50px;}
    #div2 { 1px; height:300px; position:absolute; left:300px; top:0;
     background:black;}
    </style>
    <script>
    
    function starMove(){
        var oDiv = document.getElementById('div1');
        setInterval(function(){
            var speed = (300-oDiv.offsetLeft)/10;
            speed = speed>0?Math.ceil(speed):Math.floor(speed);
            oDiv.style.left = oDiv.offsetLeft+speed+'px';
            document.title = oDiv.offsetLeft+','+speed;
            },30);
    
        }
        
        
    
    </script>
    
    <body>
    <input type=button value='移动' onclick='starMove()'>
    <div id='div1'></div>
    <div id='div2'></div>
    
    </body>
    </html>
    View Code

    效果:点击按钮,使left=0的div模块往右走,达到left=300位置停住,其过程减速过程慢慢减缓,其中用到了offsetLeft与style.left ,offsetLeft是 获取的是当前对象左侧距离父对象左侧的值。Math.ceil():向上取整,如9.5会取值10,Math.floor():向下取整,如9.5会取值9;

    十、srollTop滚动

    <style>
    body {
        
        height:2000px;}
    #div1{
        height:100px;
        150px;
        background:red;
        position:absolute;
        right:0;
        bottom:0;}    
    
    </style>
    
    <script>
    
    window.onscroll     = function(){
        var oDiv = document.getElementById('div1');
        var scrollTop = document.documentElement.scrollTop||document.body.scrollTop;
        startMove(parseInt(document.documentElement.clientHeight-oDiv.offsetHeight)+scrollTop);
        //document.documentElement.clientHeight可视区域高度
        //oDiv.offsetHeight  Div偏离父级元素的偏移位置
        //scrollTop  滚动条的高度
        };
        var timer = null;
        function startMove(iTarget){
             var oDiv = document.getElementById('div1');
             clearInterval(timer);
             timer = setInterval(function(){
                 var speed = (iTarget-oDiv.offsetTop)/6;
                 speed = speed>0?Math.ceil(speed):Math.floor(speed);
                 if(iTarget==oDiv.offsetTop){
                     clearInterval(timer);
                     }else{
                         oDiv.style.top = oDiv.offsetTop+speed+'px';
                         }
                 
                 },30);            
            
            }
    
    
    </script>
    
    
    <body height:"2000px">
    
    <div id='div1'></div>
    </body>
    </html>
    View Code

     效果: 拉着滚动条,DIv模块随之一起滚动,保持绝对位置。      //当页面滚动条刚好在最顶端,即scrollTop值为 0 时

  • 相关阅读:
    石油采集
    石油采集
    Redis 笔记与总结7 PHP + Redis 信息管理系统(用户信息的增删改查)
    数据分析电子商务B2C全流程_数据分析师
    数据分析电子商务B2C全流程_数据分析师
    数据挖掘中分类算法小结_数据分析师
    大数据分析或提升企业税务职能价值
    大数据可视化必须避免的三种常见错误
    大数据可视化必须避免的三种常见错误
    数据分析帮你预知商机
  • 原文地址:https://www.cnblogs.com/yswyzh/p/9772561.html
Copyright © 2011-2022 走看看