1. var $shadow = new Object();
  2. /**
  3. 获取元素的xpath
  4. 特性:
  5. - 转换xpath为csspath进行jQuery元素获取
  6. - 仅生成自然表述路径(不支持非、或)
  7. @param dom {String/Dom} 目标元素
  8. @returns {String} dom的xpath路径
  9. */
  10. $shadow.domXpath = function(dom) {
  11. dom = $(dom).get(0);
  12. var path = "";
  13. for (; dom && dom.nodeType == 1; dom = dom.parentNode) {
  14. var index = 1;
  15. for (var sib = dom.previousSibling; sib; sib = sib.previousSibling) {
  16. if (sib.nodeType == 1 && sib.tagName == dom.tagName)
  17. index++;
  18. }
  19. var xname =  dom.tagName.toLowerCase();
  20. if (dom.id) {
  21. xname += "[@id=\"" + dom.id + "\"]";
  22. } else {
  23. if (index > 0)
  24. xname += "[" + index + "]";
  25. }
  26. path = "/" + xname + path;
  27. }
  28. path = path.replace("html[1]/body[1]/","html/body/");
  29. return path;
  30. };
  1. /**
  2. 根据xpath获取元素
  3. 特性:
  4. - 转换xpath为csspath进行jQuery元素获取
  5. - 仅支持自然表述(不支持非、或元素选取)
  6. @param xpath {String} 目标元素xpath
  7. @returns {jQuery Object} 元素/元素集合
  8. */
  9. $shadow.xpathDom = function(xpath){
  10. // 开始转换 xpath 为 css path
  11. // 转换 // 为 " "
  12. xpath = xpath.replace(/\/\//g, " ");
  13. // 转换 / 为 >
  14. xpath = xpath.replace(/\//g, ">");
  15. // 转换 [elem] 为 :eq(elem) : 规则 -1
  16. xpath = xpath.replace(/\[([^@].*?)\]/ig, function(matchStr,xPathIndex){
  17. var cssPathIndex = parseInt(xPathIndex)-1;
  18. return ":eq(" + cssPathIndex + ")";
  19. });
  20. // 1.2 版本后需要删除@
  21. xpath = xpath.replace(/\@/g, "");
  22. // 去掉第一个 >
  23. xpath = xpath.substr(1);
  24. alert(xpath);
  25. // 返回jQuery元素
  26. return $(xpath);
  27. };
 

获取元素的xpath, 转换xpath为csspath进行jQuery元素获取的更多相关文章

  1. javascript 常见数组操作( 1、数组整体元素修改 2、 数组筛选 3、jquery 元素转数组 4、获取两个数组中相同部分或者不同部分 5、数组去重并倒序排序 6、数组排序 7、数组截取slice 8、数组插入、删除splice(需明确位置) 9、数组遍历 10、jQuery根据元素值删除数组元素的方)

    主要内容: 1.数组整体元素修改 2. 数组筛选 3.jquery 元素转数组 4.获取两个数组中相同部分或者不同部分 5.数组去重并倒序排序 6.数组排序 7.数组截取slice 8.数组插入.删除 ...

  2. 网页元素定位神器之Xpath详解

    摘要: 经常在工作中会使用到XPath的相关知识,但每次总会在一些关键的地方不记得或不太清楚,所以免不了每次总要查一些零碎的知识,感觉即很烦又浪费时间,所以对XPath归纳及总结一下. ...     ...

  3. 使用Xpath定位元素(和元素定位相关的Xpath语法)

    本文主要讲述Xpath语法中,和元素定位相关的语法 第一种方法:通过绝对路径做定位(相信大家不会使用这种方式) By.xpath("html/body/div/form/input" ...

  4. 页面元素定位及操作--xpath

    简介: 在 XPath 中,有七种类型的节点:元素.属性.文本.命名空间.处理指令.注释以及文档(根)节点.XML 文档是被作为节点树来对待的.树的根被称为文档节点或者根节点. /xxx 页面输出 / ...

  5. css选择器用法,使用css定位元素,css和xpath元素定位的区别

    css定位元素 1.什么是css? CSS(Cascading Style Sheets)层叠样式表,是一种语言,用来描述html或者xml的显示样式.在css语言中有css选择器,在selenium ...

  6. 关于xpath语句完全正确,但是页面报错: no such element: Unable to locate element: {"method":"xpath","selector":"xpath"}

    之前使用selenium-webdriver来写UI的自动化脚本,发现有一个元素一直无法定位,查看其源码,如下 利用xpathChecker验证了xpath语句的是正确的,但是控制台一直报错: no ...

  7. XPath轴(XPath Axes)总结

    XPath轴(XPath Axes)可定义某个相对于当前节点的节点集: 1.child 选取当前节点的所有子元素 2.parent 选取当前节点的父节点 3.descendant 选取当前节点的所有后 ...

  8. 了解XPath与XPath轴

    XPath 是一门在 XML 文档中查找信息的语言.XPath 用于在 XML 文档中通过元素和属性进行导航. 节点(Node) 在 XPath 中,有七种类型的节点:元素.属性.文本.命名空间.处理 ...

  9. 在 shell 脚本获取 ip、数字转换等网络操作

    在 shell 脚本获取 ip.数字转换等网络操作 ip 和数字的相互转换 ip转换为数字 :: function ip2num() { local ip=$1 local a=$(echo $ip ...

随机推荐

  1. iOS设计模式简介

    开闭原则: 一个模块的修改,对拓展开放而对修改关闭. 举个例子:有一个类在项目中很多地方被使用了,但是由于需求,想对这个类进行拓展,这里可以使用继承拓展出子类,可以对子类进行修改,尽量不要修改原来的类 ...

  2. 每日Scrum--No.8

    Yesterday:学习和编写程序 Today:总结这次的冲刺和以及测试版的初步完成 Problem:在图的设计过程中掌握了图的基本运算函数的算法的理解和程序的有效吸收,包括图的深度和广度优先的遍历, ...

  3. android:layout_gravity和android:gravity的区别

    1.首先来看看android:layout_gravity和android:gravity的使用区别. android:gravity: 这个是针对控件里的元素来说的,用来控制元素在该控件里的显示位置 ...

  4. 001.linux下clock()检测程序运行时间

    #include <stdio.h> #include <time.h> int main() { int i; int k; clock_t start,end; //clo ...

  5. git 换行符LF与CRLF转换问题

    git 换行符LF与CRLF转换问题 一.背景 在各操作系统下,文本文件所使用的换行符是不一样的.UNIX/Linux 使用的是 0x0A(LF),早期的 Mac OS 使用的是0x0D(CR),后来 ...

  6. [麦先生]如何使用AJAX实现按需加载

    按需加载的优势:在实际调查中发现,很多的网民在游览网站时具有明确的指向性,往往在进入主页后直接搜索进入自己需要的商品列表内,如果在客户进入主页时将主页信息全部加载完毕后展示给顾客,会极大的浪费网站资源 ...

  7. Libfilth(一个滤波器C库)使用

    Libfilth使用说明 winshton 2009年2月 (*本文大部分翻译自libfilth,还有一部分是个人使用实践 *时间水平均有限,翻译的不完整,尤其第二章可以忽略) 版本历史修改记录 版本 ...

  8. bitbucket和Mercurial安装和相关

    应为工作需要,需要使用bitbucket和Mercurial进行软件开发管理.下面简单介绍以下这些东西和他的安装. bitbucket是一个类似github的软件开发管理工具,和github不同,bi ...

  9. nginx 一二事(2) - 创建虚拟静态服务器

    一.什么是nginx 是一个C语言开发的HTTP反向代理服务器,性能非常高 一个俄罗斯的哥们开发的,官方提供的测试性能能够达到5W的并发,我的天呐~,实际测试差不多是2W,而淘宝的牛人可以优化到200 ...

  10. Linux压力测试工具Tsung安装、使用和图形报表生成

    简介 Tsung 是一个压力测试工具,可以测试包括HTTP, WebDAV, PostgreSQL, MySQL, LDAP, and XMPP/Jabber等服务器.针对 HTTP 测试,Tsung ...