码迷,mamicode.com
首页 > 编程语言 > 详细

python UI自动化之js操作

时间:2019-11-06 18:32:14      阅读:103      评论:0      收藏:0      [点我收藏+]

标签:move   选择器   富文本   标签   正文   技术   scrollto   code   版本   

js处理iframe无需先切换到iframe上,再切回来操作。它可以在iframe上和主页面上来回自由操作。

switch方法需要先切换到iframe上,操作完之后又的切换回来(很容易忘记切换回来),操作比较繁琐。

1、js处理富文本(富文本格式如禅道中的添加bug页面)

技术图片

 

 带iframe的元素,用js去操作contentWindow(相当于切换到iframe)

body = "这里是通过js发的正文内容"

# js处理iframe问题(js代码太长了,我分成两行了)
js = ‘document.getElementById("Editor_Edit_EditorBody_ifr").contentWindow.document.body.innerHTML="%s"‘ % body
driver.execute_script(js)

2、js定位元素的方法

(1) 通过id获取

document.getElementById("id")------获取的是单个

(2)通过name获取

document.getElementsByName("name")[0]-----获取的是多个

(3)通过标签名获取元素

document.getElementsByTagName("tag")[0]-----获取的是多个

(4)通过class类获取元素(IE8以下不支持)

document.getElementsByClassName("class")[0]-----获取的是多个

(5)通过css选择器获取元素

document.querySelectorAll("css selector")
兼容性:IE8及其以下版本的浏览器只支持CSS2标准的选择器语法  

3、js处理时间控件

一般日历控件无法手动输入时间,而要代码模拟手动选择时间特别麻烦。

要想手动输入时间,首先要将日历的readonly属性去掉,然后再给日历输入框赋值

js=‘‘‘document.getElementById("id").removeAttribute("readonly");
        document.getElementById("id").value="2019-08-19";‘‘‘
driver.execute_script(js)    

技术图片

 4、div内嵌滚动条

首先定位到有滚动条的元素,然后再通过scrollTop、scrollLeft控制滚动条

js1=‘document.getElementById("id").scrollTop=100;‘------控制竖向滚动条
driver.execute_script(js)
js2=‘document.getElementById("id").scrollLeft=1000;‘------控制横向滚动条
driver.execute_script(js2)

 

python UI自动化之js操作

标签:move   选择器   富文本   标签   正文   技术   scrollto   code   版本   

原文地址:https://www.cnblogs.com/wulixia/p/11806587.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!