som*_*491 3 javascript python selenium-webdriver
我想通过执行javascriptin来隐藏画布元素上的元素python。
我已经尝试过以下:
def hide_elements():
driver = LiveLibrary.get_webdriver_instance()
js_script = '''\
element1 = document.getElementsByClassName('someclass');
element1[0].style.display = 'none';
element2 = document.getElementsByClassName('another');
element2[0].style.display = 'none';
element3 = document.getElementsByClassName('highlight');
element3[0].style.display = 'none';
element4 = document.getElementsByClassName('overlay');
element4[0].style.display = 'none';
'''
driver.execute_script(js_script)
Run Code Online (Sandbox Code Playgroud)
上面的代码有效,但正如您所看到的,有重复的代码。有没有办法可以简化这个过程,而不是找到每个元素并隐藏它们?
如果每个类只有一个 - 我使用 ES<5 来不破坏你的网络驱动程序:
var cls = ["someclass","another","highlight","overlay"];
for (var i=0;i<cls.length;i++) {
document.querySelector("."+cls[i]).style.display = "none";
}
Run Code Online (Sandbox Code Playgroud)
这在浏览器中可以工作:
[...document.querySelectorAll("[class^=class]")].forEach(ele => ele.style.display = "none");
Run Code Online (Sandbox Code Playgroud)
对于不同的班级:
["someclass","another","highlight","overlay"]
.forEach(cls => [...document.querySelectorAll("."+cls)]
.forEach(ele => ele.style.display = "none"));
Run Code Online (Sandbox Code Playgroud)
对于旧的 JS 版本:
["someclass","another","highlight","overlay"]
.forEach(function(cls) { [...document.querySelectorAll("."+cls)]
.forEach(function(ele) { ele.style.display = "none"})});
Run Code Online (Sandbox Code Playgroud)
甚至更老:
var cls= ["someclass","another","highlight","overlay"];
for (var i=0;i<cls.length;i++) {
var elements = document.querySelectorAll("."+cls[i]);
for (var j=0;j<elements.length;j++) {
elements[j].style.display = "none";
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
8355 次 |
| 最近记录: |