概述
今天我们讲讲switch_to家中的一个异类:switch_to.active_element,当然,我们先普及一下其他的家族成员。
1.switch_to
selenium做自动化的过程中,经常会遇到alert、frame和新的window,这是经常是switch_to家族大展拳脚的时候,先看看switch_to家族的成员:
alert ——返回浏览器的Alert对象,可对浏览器alert、confirm、prompt框操作
default_content() ——切到主文档
frame(frame_reference) ——切到某个frame
parent_frame() ——切到父frame,这个方法也不常被人所知,但有多层frame的时候很有用,不过这里要提一句,一般这种嵌套多层的frame都是有问题的,会影响到性能,可以提给开发,让其改进
window(window_name) ——切到某个浏览器窗口
active_element ——返回当前焦点的WebElement对象
其中:
- alert和window的操作在之前的博客selenium之 辨识alert、window以及操作中已经讲到
- 关于frame的三个方法也在之前的博客selenium之 定位以及切换frame(iframe)中已经讲到
唯一没有说到的就是switch_to家族中的active_element成员,这个家伙不常被用到,所以也容易被人遗忘,在网上也很少找到关于它的介绍。但是,存在的即是合理的,它也必然有它存在的意义。
2.switch_to.active_element
switch_to.active_element返回的是当前焦点的对象,即返回WebElement对象。
那么焦点是什么?大概可以这样理解:即网页上当前操作的对象(也就是你网页上光标的位置),比如,你鼠标点击到了一个input框,你可以在这个input框里输入信息,这时这个input框即焦点。
说了半天,到底什么时候会需要返回当前的焦点呢?下面这个例子可以更直观一些:
今天群里有人遇到这样的问题,一个网页上的新建文件夹的功能,右键-新建之后,在页面上有个输入文件夹名的input框,但这个框一旦失去焦点而且没有内容的话,就会消失、取消掉新建文件夹的操作。如图:
最初的代码如下(部分):
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
结果这种操作总会导致输入框失去焦点,直接消失,更不能send_keys进去了,直接报错。
我提醒用ActionChains的send_keys发送,不去重新定位元素,就用默认的焦点元素。修改后的代码如下(部分):
- 1
- 2
- 3
- 4
- 5
- 6
- 1
- 2
- 3
- 4
- 5
- 6
结果仍是失败,代码执行成功了。但是光标仍卡在输入框,输入框也没有输入任何信息。
没办法,只好祭出我的大招,用switch_to.active_element,看代码(部分):
- 1
- 2
- 3
- 4
- 1
- 2
- 3
- 4
结果:
成功添加上了新的文件夹!
注意:active_element后面没有括号。
有上面的示例我想大家也大概明白了active_element的用法。当你想要获取当前焦点元素时,你就可以用它了。
API : Returns the element with focus, or BODY if nothing has focus.
最后
以上就是清秀书包为你收集整理的selenium之 一个不常用但又很有用的方法(switch_to.active_element),获取当前焦点元素的全部内容,希望文章能够帮你解决selenium之 一个不常用但又很有用的方法(switch_to.active_element),获取当前焦点元素所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复