zoukankan      html  css  js  c++  java
  • 2018阿里前端实习在线编程实现一个css选择器总结

    题目:实现一个getCssSelector方法,可以根据给定的元素生成一个css选择器,通过这个选择器可以快速定位到这个元素(document.querySelector(A))

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
    </head>
    <body>
        <div id="page">
            <div class="content main">
                <div class="refer">
                    <ul>
                        <li></li>
                        <li></li>
                        ...
                    </ul>
                 </div>
            </div>
        </div>
    </body>
    </html>
    <script type="text/javascript">
    //根据上述HTML结构,完善如下JavaScript代码中的“your code here”部分,使得click事件中的注释要求符合预期:
    var genCssSelector = function(){
        // your code here

        }

    document.addEventListener('click', function(e){
        //点击li时,返回:html body #page .content.main .refer ul li
        console.log(genCssSelector(e.target));
    })

    </script>

    扩展:

    Document 对象使我们可以从脚本中对 HTML 页面中的所有元素进行访问。

    提示:Document 对象是 Window 对象的一部分,可通过 window.document 属性对其进行访问。

    分析:

    刚开始没读懂题,看了下面的注释才知道要输出什么,考察DOM是树形关系,如何获取父元素是本题的关键。

    我的代码:

     1 var genCssSelector = function(){
     2         var element=arguments[0];//函数传入的第一个参数,即点击元素
     3         var parentElement=element.parentNode;//点击元素的父元素
     4         var strGenCssSelector=element.tagName.toLowerCase()//获取点击的元素的标签名
     5         while(parentElement.nodeName.toLowerCase()!=='#document'){
     6             if(parentElement.id!==''){//父元素有id
     7                 strGenCssSelector='#'+parentElement.id+' '+strGenCssSelector;
     8                 parentElement=parentElement.parentNode;
     9                 continue;
    10             }else if(parentElement.className!=''){//父元素有class
    11                     strGenCssSelector=' '+strGenCssSelector;
    12                     var classList=parentElement.className.split(' ');//按照空格分隔className,存入classList数组里
    13                     for(var i=classList.length-1;i>=0;i--){//逆序输出
    14                         strGenCssSelector='.'+classList[i]+strGenCssSelector;
    15                     }
    16                     parentElement=parentElement.parentNode;
    17                     continue;
    18             }else{
    19                     strGenCssSelector=parentElement.nodeName.toLowerCase()+' '+strGenCssSelector;
    20                     parentElement=parentElement.parentNode;
    21                     continue;
    22             }
    23         }
    24         return strGenCssSelector;
    25     }
  • 相关阅读:
    2020杭电HDU-6831多校第六场Fragrant numbers(区间DP打表)
    Gym 102219H-Are You Safe?(凸包求解+判断点与凸包关系)
    2020杭电HDU-6827多校第六场Road To The 3rd Building(找规律求期望)
    洛谷P1099&Noip 2007提高-树网的核(树直径上的尺取)
    2020杭电HDU-6832多校第六场A Very Easy Graph Problem(最短路转最小生成树+dfs)
    CodeForces 950D-A Leapfrog in the Array(打表找规律)
    使用odoo价格表[pricelist]对价格进行特别处理,如 .99
    odoo 10 生产自动领料
    安装odoo服务
    advanced validation on purchase.
  • 原文地址:https://www.cnblogs.com/shenminer/p/8610015.html
Copyright © 2011-2022 走看看