Js学习---妙味课堂2-1

DOM元素+文档碎片

创建,插入,删除一个新的DOM元素:

例一:

window.onload = function(){
    var oUl=document.getElementById('ul1');
    var oBtn=document.getElementById('btn1');
       //注意! 这里的var变量设置,也需要写在 window.onload里面!才会去即时实现它
    oBtn.οnclick=function(){
        // creatElement('标签名');
        var oLi=document.createElement('li');
        //父.appendChild(子节点)
        oUl.appendChild(oLi);
    }
}

// createElement('');  and  appendChile(名称);  // text中输入的值,可以通过其 value获得。

例二: 

window.onload = function(){
    var oUl=document.getElementById('ul1');
    var oBtn=document.getElementById('btn1');
    var oText1=document.getElementById('text1');
       //注意! 这里的var变量设置,也需要写在 window.onload里面!才会去即时实现它
    oBtn.οnclick=function(){
        // creatElement('标签名');
        var oLi=document.createElement('li');
        oLi.innerHTML=oText1.value;
        //父.appendChild(子节点)
        oUl.appendChild(oLi);
    }
}

例三:---在某一元素之前插入。   使用  insertBefore(子节点,谁之前)

window.onload = function(){
    var oUl=document.getElementById('ul1');
    var oBtn=document.getElementById('btn1');
    var oText1=document.getElementById('text1');
       //注意! 这里的var变量设置,也需要写在 window.onload里面!才会去即时实现它
    oBtn.οnclick=function(){
        // creatElement('标签名');
        var oLi=document.createElement('li');
        var aLi=oUl.getElementsByTagName('li');
        oLi.innerHTML=oText1.value;
        
        oUl.insertBefore(oLi,aLi[0]);
    }
}

//但是当之前没有li时,创建会报错。  解决方法: 加一个if  else 判断。

代码:

     if(aLi.length==0){
            oUl.appendChild(oLi);
        }
        else{
            oUl.insertBefore(oLi,aLi[0]);
        }

删除DOM元素:

--- removeChild();

window.onload = function(){
    var aA=document.getElementsByTagName('a'); //一定要注意大小写!!!
    var oUl=document.getElementById('ul1');
    var i=0;
    for(i=0;i<aA.length;i++){
        aA[i].onclick=function(){
            oUl.removeChild(this.parentNode);
        }
    }
}

 

文档碎片:--- 相当于一个口袋

可以提高DOM操作性能(理论上---减少渲染次数)

文档碎片原理

document.creat3DocumentFragment();

//其实一般不怎么用

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值