首页 > 编程语言 > 详细

Javascript获取元素的xpath

时间:2019-08-28 11:47:42      阅读:123      评论:0      收藏:0      [点我收藏+]
//获取xpath
function readXPath(element) {
    if (element.id !== "") {//判断id属性,如果这个元素有id,则显 示//*[@id="xPath"]  形式内容
        return ‘//*[@id=\"‘ + element.id + ‘\"]‘;
    }
    //这里需要需要主要字符串转译问题,可参考js 动态生成html时字符串和变量转译(注意引号的作用)
    if (element == document.body) {//递归到body处,结束递归
        return ‘/html/‘ + element.tagName.toLowerCase();
    }
    var ix = 1,//在nodelist中的位置,且每次点击初始化
         siblings = element.parentNode.childNodes;//同级的子元素
 
    for (var i = 0, l = siblings.length; i < l; i++) {
        var sibling = siblings[i];
        //如果这个元素是siblings数组中的元素,则执行递归操作
        if (sibling == element) {
            return arguments.callee(element.parentNode) + ‘/‘ + element.tagName.toLowerCase() + ‘[‘ + (ix) + ‘]‘;
            //如果不符合,判断是否是element元素,并且是否是相同元素,如果是相同的就开始累加
        } else if (sibling.nodeType == 1 && sibling.tagName == element.tagName) {
            ix++;
        }
    }
};

 

Javascript获取元素的xpath

原文:https://www.cnblogs.com/hhmm99/p/11423072.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!