java 获取页面元素的位置_java+selenium——查找定位元素,以及对浏览器窗口的简单操作...

1ac3358b06e601027a8f1d30f562577b.png

packagerjcs;importorg.openqa.selenium.firefox.FirefoxDriver;public classqhjb

{public static voidmain(String[] args)

{

System.setProperty("webdriver.firefox.bin","C:\\Program Files (x86)\\Mozilla Firefox\\firefox.exe"); //设置火狐的安装路径,防止系统找不到

FirefoxDriver driver= new FirefoxDriver(); //初始化FireFox浏览器实例,并打开浏览器

try{

driver.manage().window().maximize();//最大化窗口

Thread.sleep(5000);

driver.get("https://www.baidu.com"); //打开一个网址,方法一//driver.findElementByLinkText("地图").click();//通过连接文字打开地图

boolean a= driver.findElementById("kw").isDisplayed(); //是否看见

System.out.println("元素是否可见:"+a);boolean b= driver.findElementById("kw").isEnabled(); //是否可编辑操作

System.out.println("元素是否编辑:"+b);

String s= driver.findElementById("kw").getTagName(); //查看标签名字

System.out.println("kw标签名字:"+s);

String w= driver.findElementById("su").getTagName(); //查看标签名字

System.out.println("su标签名字:"+w);

String p= driver.findElementById("kw").getAttribute("class"); //用于获取元素的属性值

System.out.println("kw的class属性值名字:"+p);

String g= driver.findElementByPartialLinkText("图").getText();

System.out.println("连接文字 地图 的 文本值:"+g);

Thread.sleep(10000);

driver.findElementById("kw").sendKeys("中国");

Thread.sleep(10000);

driver.findElementById("kw").clear();

Thread.sleep(10000);

driver.findElementById("kw").sendKeys("美国");

driver.findElementById("su").click();

Thread.sleep(10000);

}catch(Exception e)

{

e.printStackTrace();

}finally{

driver.quit();

}

}

}

执行结果:

元素是否可见:true

元素是否编辑:true

kw标签名字:input

su标签名字:input

su标签名字:s_ipt

连接文字 地图 的 文本值:地图

====================================================================================================================

packagerjcs;importorg.openqa.selenium.Dimension;importorg.openqa.selenium.Point;importorg.openqa.selenium.firefox.FirefoxDriver;public classnjcsxdy

{public static voidmain(String[] args)

{

System.setProperty("webdriver.firefox.bin","C:\\Program Files (x86)\\Mozilla Firefox\\firefox.exe"); //设置火狐的安装路径,防止系统找不到

FirefoxDriver driver= new FirefoxDriver(); //初始化FireFox浏览器实例,并打开浏览器

try{

driver.manage().window().maximize();//最大化窗口

Thread.sleep(5000);

Dimension targetSize= new Dimension(300,500); //设置窗口大小为1024*768

driver.manage().window().setSize(targetSize);

System.out.println(driver.manage().window().getSize());//获取窗口的大小

Thread.sleep(5000);

Point targetPosition01= new Point(300, 600); //设置窗口左上角那个点出现的位置为(300,600)

driver.manage().window().setPosition(targetPosition01);

System.out.println(driver.manage().window().getPosition());

Thread.sleep(5000);

Point targetPosition02= new Point(600, 800); //设置窗口左上角那个点出现的位置为(600,800)

driver.manage().window().setPosition(targetPosition02);

System.out.println(driver.manage().window().getPosition());

Thread.sleep(5000);

driver.manage().window().maximize();//最大化窗口

Thread.sleep(5000);

driver.get("https://www.baidu.com"); //打开一个网址,方法一//driver.findElementByLinkText("地图").click();//通过连接文字打开地图

boolean a= driver.findElementById("kw").isDisplayed(); //是否看见

System.out.println("元素是否可见:"+a);boolean b= driver.findElementById("kw").isEnabled(); //是否可编辑操作

System.out.println("元素是否编辑:"+b);

String s= driver.findElementById("kw").getTagName(); //查看标签名字

System.out.println("kw标签名字:"+s);

String w= driver.findElementById("su").getTagName(); //查看标签名字

System.out.println("su标签名字:"+w);

String p= driver.findElementById("kw").getAttribute("class"); //用于获取元素的属性值

System.out.println("kw的class属性值名字:"+p);

String g= driver.findElementByPartialLinkText("图").getText();

System.out.println("连接文字 地图 的 文本值:"+g);

Thread.sleep(10000);

driver.findElementById("kw").sendKeys("中国");

Thread.sleep(10000);

driver.findElementById("kw").clear();

Thread.sleep(10000);

driver.findElementById("kw").sendKeys("美国");

driver.findElementById("su").click();

Thread.sleep(10000);

driver.navigate().to("https://www.ifeng.com"); //此页面打开新页面

Thread.sleep(10000);

driver.navigate().back();//后退

Thread.sleep(10000);

driver.navigate().forward();//前进

Thread.sleep(10000);

driver.navigate().refresh();//刷新当前页

Thread.sleep(10000);

}catch(Exception e)

{

e.printStackTrace();

}finally{

driver.quit();

}

}

}

执行结果:

(300, 500)

(300, 600)

(600, 800)

元素是否可见:true

元素是否编辑:true

kw标签名字:input

su标签名字:input

kw的class属性值名字:s_ipt

连接文字 地图 的 文本值:地图

=====================================================================================================================

(1)、标准写法

标准写法为//标签名[@属性名="属性值"],比如我们要找那个title为搜索热点的元素,则xpath就是这样写//div[@title='搜索热点'](这里属性值用单引号或者双引号都可以,//这个意思是从全局元素始中查找);

(2)、获取父元素

获取父元素,xpath语句中要加个/..即可,so要多级父元素,就多加几个即可,比如我们要获取上图中最上面那个div元素,其xpath可以这样写//div[@title='搜索热点']/../../..;

(3)、获取兄弟元素

获取兄弟元素,这个就可以先定位到其父元素,再下级寻找,比如上图黄色标识那个元素,xpath就可以这样写//div[@title='搜索热点']/../table;

(4)、多属性方式定位

有时候我们用单一属性进行查找还是会有重复的元素,那么怎么办呢,其实属性我们可以加多个,譬如上图中那个a标签元素,其xpath就可以这样写//a[@title='谢霆锋山寨歌迷会'][text()='谢霆锋山寨歌迷会'],注意那个[text()='谢霆锋山寨歌迷会']为text的专有写法;

(5)、获取子元素

子元素获取,子元素的话就比较简单了,可以直接在元素后加[n]就可以了,譬如要获取上图中第二个td标签的元素,则xpath可以写为//a[@title='谢霆锋山寨歌迷会'][text()='谢霆锋山寨歌迷会']/../../../td[2],注意这个td[2]中的2即为其编号,这里编号都是从1开始,如果是第一个td则可以不用加后边那个[1];

其实有个简单方法,即在chrome的开发者工具中,选中要定位的元素,右键选择copy Xpath就可以获取到其xpath,只是有时候这个xpath会很长…所以建议还是自己写比较好;

以上那5中方法是可以灵活配合使用的。

8、通过css选择器查找

与通过xpath查找类似,这个也可以直接在chrome中点击要定位的元素右键选择cssSelector来获取其css选择器,不过和xpath一样有时候会很长…不如自己写的简单(需要注意的是css选择器方式有时候写起来比xpath要简单许多,建议这个好好学习下);

这部分详细教程可以参考这个链接:http://www.w3school.com.cn/cssref/css_selectors.asp

========================================================================================================================

下面简单讲下常用方法:

(1)、通过id方式

这里的selector可以写为#id_value或者带tag名称的方式tag_name#id_value,其中tag_name为类似div这种,id_value则是该元素的id属性的值;

(2)、通过class方式

此处selector可以写为.class_value或者带tag名称的方式tag_name.class_value,此处的class_value为元素的class属性的value值;

(3)、通过其他属性的方式

此处selector可以写为[attr_name="attr_value"]或者[attr_name='attr_value'],此种方式也可以带个tag名称,直接加在中括号前面即可;

(4)、通过tag_name的方式

此处selector写法为tag_name,这样可以直接获取到所有标签名为tag_name的元素,结果同tagName查找方式;

(5)、通过路径方式

此处selector写法为tag_name>tag_name,当然tag_name可以带属性,路径可以有多层;

如上几种方式可以配合使用;

===============================================================================================================

三、元素的基本操作

1、点击

代码为element.click(),此操作用于所有可以点击的操作,注意不能点击的元素用click操作会抛异常;

2、清除

代码为element.clear(),此操作用于input输入框,在输入字符串之前建议先clear下,以避免有数据导致内容输入异常;

3、发送数据

代码为element.sendKeys(keys),此操作用于input输入框;

4、提交数据

代码为element.submit(),此操作常用于form元素块儿的提交按钮,一般和发送数据配合使用,登录框比较常见;

5、获取属性

代码为element.getAttribute(attr_key),用于获取元素的属性值,attr_key为属性的key值;

6、获取css值

代码为element.getCssValue(css_key),用于获取元素的某个css值,css_key为css属性名称;

7、获取位置

代码为element.getLocation(),用于获取元素的位置信息,即该元素左上角在整个浏览器中的坐标;

8、获取大小

代码为element.getSize(),用于获取元素的大小信息,即该元素的长和宽信息,常用于元素截图,和获取位置配合使用,可以获取元素块儿其他三个点的坐标;

9、获取tag_name

代码为element.getTagName();,用于获取元素的tag名称;

10、获取内容

代码为element.getText(),用于获取元素的text的值;

11、查找元素

代码为element.findElement(By),用于根据以该元素为原点获取元素,此处不太常用;

12、是否显示

代码为element.isDisplayed(),返回该元素是否显示,对应元素的这个属性style="display: block;";

13、是否enable

代码为element.isEnable(),常用于单选框等;

14、是否被选择

代码为element.isSelected(),此项用于select元素块儿。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值