iframe的属性获取

必须先切换到 iframe 内,才能访问内部文档的属性,

python 复制代码
driver.switch_to.frame(iframe_element)  # 切换到 iframe

获取文档标题(document.title

python 复制代码
title = driver.title  # 直接获取当前文档标题
# 或通过 JS
title = driver.execute_script("return document.title")

当前 iframe 内页面的 URL

iframe 内页面的 URL 并不是浏览器地址栏的 URL,而是其自身加载的地址。用driver.current_url获取到是主文档的url,并不是iframe的URL

可以通过以下方式获取:

python 复制代码
current_url_in_iframe = driver.execute_script("return document.location.href")

获取iframe的加载状态

python 复制代码
iframe_ready_state = driver.execute_script("return document.readyState")

获取来源页面 URL

python 复制代码
iframe_referrer = driver.execute_script("return document.referrer")

获取页面性能/几何信息

python 复制代码
# 页面可视区域宽高
viewport_width = driver.execute_script("return window.innerWidth")
viewport_height = driver.execute_script("return window.innerHeight")

# 页面总宽高(含滚动)
page_width = driver.execute_script("return document.body.scrollWidth")
page_height = driver.execute_script("return document.body.scrollHeight")

完整示例:

python 复制代码
# 假设已定位到 iframe 元素
iframe = driver.find_element(By.CSS_SELECTOR, "iframe.layui-layer-iframe")

# 获取 iframe 本身的属性
iframe_src = iframe.get_attribute("src")
iframe_title_attr = iframe.get_attribute("title")

# 切换到 iframe
driver.switch_to.frame(iframe)

# 获取内部文档的标题和 URL(同域下)
inner_title = driver.title
inner_url = driver.execute_script("return document.location.href")

print(f"iframe 元素 src: {iframe_src}")
print(f"iframe 元素 title 属性: {iframe_title_attr}")
print(f"iframe 内部文档标题: {inner_title}")
print(f"iframe 内部文档 URL: {inner_url}")

# 切回主页面
driver.switch_to.default_content()

注意事项

  1. 跨域限制 :如果 iframe 加载的是不同域的页面(如外部网站),出于浏览器安全策略,你将无法通过 driver.execute_script() 访问其内部的 document 属性(会报跨域错误)。这种情况下只能获取 iframe 元素本身的属性(如 srctitle 等)。

  2. 等待加载:在获取内部文档属性前,确保 iframe 已经完全加载,可以使用:

    python 复制代码
    driver.switch_to.frame(iframe_element)
    
    WebDriverWait(driver, 10).until
    (lambda d: d.execute_script("return document.readyState") == "complete")
  3. 切换回主页面:操作完 iframe 后,记得切回默认内容:

    python 复制代码
    driver.switch_to.default_content()
相关推荐
山河木马10 小时前
矩阵专题3-怎么创建投影矩阵(uProjectionMatrix)
javascript·webgl·计算机图形学
泯泷11 小时前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
泯泷11 小时前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
朦胧之12 小时前
页面白屏卡住排查方法
前端·javascript
犇驫聊AI13 小时前
Chrome DevTools MCP + Claude Code 自定义skills生成接口代码生成器
前端·javascript
kyriewen13 小时前
别再这样写 async/await 了:我在 Code Review 中见过最多的 8 个错误
前端·javascript·面试
用户2986985301418 小时前
在 React 中使用 JavaScript 将 Excel 转换为 SVG
前端·javascript·react.js
labixiong18 小时前
手写Promise--微任务、静态方法、async/await 全搞懂(三)
前端·javascript
铁皮饭盒20 小时前
3行代码搞定页面截图,Bun.WebView真的简单
javascript
kyriewen1 天前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试