zoukankan      html  css  js  c++  java
  • JS——DOM

    自定义属性操作

        标签自带属性:idclassonclick等固有属性

        支持添加属性:获取固有属性,undefined

        获取属性(自定义、固有均支持):  -getAttribute('自定义id名')

        设置属性                        -setAttribute('id名',"vale")

        移除属性:          removeAttribut('属性名')    或者:box.class='';[将值设为空]

        元素.属性   一般只对固有属性进行操作。

        h5设置: data-自定义属性名  data=idx -->  但是获取自定义属性: box.dataset.idx [ie11开始支持]

                                                                    box.dataset[idx]

        //孩子节点 a instanceof Array:并不是数组,只是类数组对象

        ul.childNodes   //注意:包含所有儿子:文本、li、注释、回车换行{

            即: 其长度问题注意!

            ele.nodeType : {

                1:li,元素节点

                3:文本节点,回车换行

                8:注释节点

            }

        }

    //box.nextSibling:下一个兄弟节点,包括:元素,文本节点等

    //box.nextElementSibling:下一个兄弟元素

    //同理:previous

    // chrome ,fireFox火狐开发插件

        element.parentNode      父亲节点

        //获取html元素——父亲为 #document  [document无上一级,返回null]

        var oHtml = document.documentElement

                    document.html

        //不同浏览器兼容性问题:考虑版本问题【完全跟金融领域,又是另一种思维】或者期本质一样,不同金融工具

        //孩子节点 a instanceof Array:并不是数组,只是类数组对象

        ul.childNodes   //注意:包含所有儿子:文本、li、注释、回车换行{

            即: 其长度问题注意!

            ele.nodeType : {

                1:li,元素节点

                3:文本节点,回车换行

                8:注释节点

            }

        }

        // children属性:得到元素的所有子元素-->具体定位某个节点     重点掌握:得到元素的所有元素子节点

        ul.children.length

        // firstChild : 所有孩子的第一个节点【所有儿子包括文本节点中选择第一个】 --- lastChild

        // firstElementChild : ie9+以后支持

    //表格删除行列

    tbody.removeChild(this.parentNode.parentNode);        //tbody.removeChild(tr)

    对象禁用

    btn.onclick = function() {

    if (ul.children.length > 0) {

    let eleRe = ul.removeChild(ul.children[0]);

    console.log(eleRe);

                } else {

    btn.disabled = true;

                }

            }


    行内样式为: 建议双引号,“”

    元素查找——>元素操作

        获取元素地内容

        innnerHTML  支持标签

        innerText   不支持


    ondbclick:双击事件

    // appendChild:在末尾添加儿子

    oUl.appendChild(oLi);

    // 第二个参数:参照物,// // 在一个儿子前添加,如果不存在null,在末尾添加

    oUl.insertBefore(oLi, null);

    //在第几个元素前添加元素

    oUl.insertBefore(oLi, oUl.children[0]);


    //复制第一个li到末尾ul

    var ul = document.getElementsByTagName('ul')[0];

    var first = ul.children[0];

    ul.appendChild(first); //剪切粘贴

    //克隆一份

    var clone1 = ul.children[0].cloneNode(true); //cloneNode():默认参数为false,浅复制;true为深复制

    ul.appendChild(clone1);


    父亲做代理,来处里儿子点击事件

    // true:表示在捕获阶段监听; false:表示在冒泡阶段监听

    <div class="fa">

    <div class="son"></div>

    </div>

    <script>

    var fa = document.querySelector('.fa');

    var son = document.querySelector('.son');

    // onclick  attachEvent

    son.addEventListener('click', function() {

    console.log('冒泡 son');

            }, false);

    fa.addEventListener('click', function() {

    console.log('冒泡 fa');

            }, false);

    document.addEventListener('click', function() {

    console.log('冒泡 documnet');

            }, false);


    son.addEventListener('click', function() {

    console.log('true son');

            }, true);

    fa.addEventListener('click', function() {

    console.log('true fa');

            }, true);

    document.addEventListener('click', function() {

    console.log('true documnet');

            }, true);

    </script>


    function addEventListener(ele, eventName, fn) {

    if (ele.addEventListener) {

    ele.addEventListene(eventName, fn);

                } else if (ele.attachEvent) {

    ele.attachEvent('on' + eventName, fn);

                } else {

    ele['on' + eventName] = fn;

                }

            }

    addEventListener(btn, 'mouseover', function() {

    console.log('ok');

            });


    精灵图:
    1、精灵图技术产生的目的:很多大型网页在首次加载的时候都需要加载很多的小图片,而考虑到在同一时间,
         服务器拥堵的情况下,为了解决这一问题,采用了精灵图这一技术来缓解加载时间过长从而影响用户体验的这个问题。

    2、精灵图技术的本质:所谓精灵图就是把很多的小图片合并到一张较大的图片里,所以在首次加载页面的时候,
         就不用加载过多的小图片,只需要加载出来将小图片合并起来的那一张大图片也就是精灵图即可,这样在一定程度上减少了
         页面的加载速度,也一定程度上缓解了服务器的压力。

  • 相关阅读:
    Writing Custom Providers
    terraform 几个方便的工具
    几张简单的terraform flow 图——可以快速了解terraform的使用
    Stateful Kubernetes Applications Made Easier: PSO and FlashBlade
    使用k8s && minio 进行 postgres 数据库自动备份
    Understanding how uid and gid work in Docker containers
    nightwatchjs 基于nodejs&& webdriver 协议的自动化测试&&持续集成框架
    hasura graphql-engine graphql2chartjs 方便的graphql 转换chartjs 的类库
    nginx unit 1.8 支持基于java servlet 的开发模型
    试用 openresty/lua-resty-shell
  • 原文地址:https://www.cnblogs.com/macro-renzhansheng/p/13025975.html
Copyright © 2011-2022 走看看