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. swift2.2当中的inout参数的使用

    在Swift中,初次接触inout关键字以及它的用法,可能会让我们想起C/C++中的指针,但实际上Swift中inout只不过是按值传递,然后再写回原变量,而不是按引用传递: An in-out pa ...

  2. android学习笔记 activity生命周期&任务栈&activity启动模式

    activity生命周期 完整生命周期 oncreate->onstart->onresume->onpause->onstop->ondestory 使用场景:应用程序 ...

  3. 2、IOS开发--iPad之仿制QQ空间 (初始化HomeViewController子控件视图)

    1.先初始化侧边的duck,效果图: 实现步骤: 2.然后初始化BottomMenu,效果: 步骤: 其实到这里,会出现一个小bug,那就是: 子控件的位置移高了,主要原因是: 逻辑分析图: 问题解决 ...

  4. Saiku 下载,安装

    Saiku是一个模块化的开源分析套件,它提供轻量级的OLAP(联机分析处理),并且可嵌入.可扩展.可配置. 主页:http://community.meteorite.bi 如何安装摘自: http: ...

  5. oracel数据泵的使用

    1.查看目录,用下面任意一条查询语句即可. select * from dba_directories;         select * from ALL_DIRECTORIES; 2.一般安装好数 ...

  6. su su -

    http://www.ha97.com/4001.html su命令和su -命令最大的本质区别就是:前者只是切换了root身份,但Shell环境仍然是普通用户的Shell:而后者连用户和Shell环 ...

  7. Eclipse中使用Working Set来管理项目

    Eclipse作为一款流行的JavaIDE开发工具,其有很多好用的功能为我们的开发提供帮助.但我们的工作空间中有很多项目时,管理起来就很头疼了. 但是我们又不想更换工作区间,所以我们需要一个更加有效的 ...

  8. python datetime模块用strftime 格式化时间

    1 2 3 #!usr/bin/python import datetime datetime.datetime.now() 这个会返回 microsecond.因此这个是我们不需要的.所以得做一下修 ...

  9. oracle 11g dataguard创建的简单方法

    oracle 10g可以通过基于备份的rman DUPLICATE实现dataguard,通过步骤需要对数据库进行备份,并在standby侧进行数据库的恢复.而到了11g,oracle推出了Dupli ...

  10. [嵌入式学习资料]ARM开发学习详解iTOP-4412开发板使用手册

    拿到的最新4412开发板学习使用手册,完全免费,分享一下 下载地址:http://pan.baidu.com/s/1ntrJA8h