- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要能够对 QWebPage 中的焦点变化使用react。我使用了 microFocusChanged() 信号,它给了我几乎理想的行为,但无论如何我不知道如何知道选择了哪个元素。当页面上的任何可编辑元素获得或失去焦点时,我想执行一些操作。
提前致谢
最佳答案
要处理页面中的任何 HTML 事件,您可以执行以下操作:
添加焦点更改处理程序的 JavaScript 应该遍历所有文本元素并添加 onfocus 和 onblur 处理程序。更好的方法是将单个处理程序添加到 documentElement 并使用事件冒泡。不幸的是,onblur ad onfocus 不冒泡。幸运的是,他们有一个冒泡的对应物,称为 DOMFocusIn 和 DOMFocusOut。
下面是捕获页面文本元素的焦点入/出事件的完整示例。它在主窗口上声明了两个插槽 handleFocusIn
和 handleFocusOut
以供 JavaScript 调用,并将主窗口注册为名为 MainWindow
的全局 JavaScript 变量。然后运行 JavaScript 将 DOMFocusIn/DOMFocusOut 事件绑定(bind)到这些插槽(间接地,因为我们需要过滤掉非文本元素)。
import sip
sip.setapi("QString", 2)
sip.setapi("QVariant", 2)
from PyQt4 import QtCore, QtGui, QtWebKit
class MyDialog(QtGui.QMainWindow):
def __init__(self):
super(MyDialog, self).__init__()
self.setWindowTitle("QWebView JavaScript Events")
web_view = QtWebKit.QWebView(self)
web_view.setHtml("""
<html>
<body>
<input type="text" name="text1"/><br/>
<input type="text" name="text2"/><br/>
<input type="submit" value="OK"/>
</body>
</html>""")
self.setCentralWidget(web_view)
main_frame = web_view.page().mainFrame()
main_frame.addToJavaScriptWindowObject("MainWindow", self)
doc_element = main_frame.documentElement()
doc_element.evaluateJavaScript("""
function isTextElement(el) {
return el.tagName == "INPUT" && el.type == "text";
}
this.addEventListener("DOMFocusIn", function(e) {
if (isTextElement(e.target)) {
MainWindow.handleFocusIn(e.target.name);
}
}, false);
this.addEventListener("DOMFocusOut", function(e) {
if (isTextElement(e.target)) {
MainWindow.handleFocusOut(e.target.name);
}
}, false)
""")
self.resize(300, 150)
@QtCore.pyqtSlot(QtCore.QVariant)
def handleFocusIn(self, element_name):
QtGui.QMessageBox.information(
self, "HTML Event", "Focus In: " + element_name)
@QtCore.pyqtSlot(QtCore.QVariant)
def handleFocusOut(self, element_name):
QtGui.QMessageBox.information(
self, "HTML Event", "Focus Out: " + element_name)
app = QtGui.QApplication([])
dialog = MyDialog()
dialog.show()
app.exec_()
(如果您真的不懂 Python,我可能会用 C++ 重写)。
关于qt - 如何在 QWebView/QWebPage 中获取焦点元素?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2843998/
我正在使用 Qt 中的单选项卡浏览器,但遇到了一个问题: 指向外部网站的网络链接设置为在新选项卡中打开(使用 taget='_blank')。但是,由于我的浏览器只有一个选项卡,因此这些链接根本处于非
我想知道如何使用 QWebPage 获取当前页面的 mime 类型。另外,如果可能的话,我希望能够使用 HEAD 请求来做到这一点,这样我就知道如果它不是正确的 mime 类型就不要下载整个页面。有什
我有这个代码: class TestThread : public QThread { public: void run() { QFile file("test.ht
我正在编写一个使用 QWebPage 抓取一些网页的应用程序。当响应是 Http 重定向(例如 302、303 等)时,我遇到了一些麻烦。 QWebPage 根本不遵循重定向。 为了解决这个问题,我已
QWebView 的文档(至少在 PyQt 中)说:“QWebView 类提供了一个用于查看和编辑 Web 文档的小部件”,而 QWebPage说:“QWebPage 类提供了一个对象来查看和编辑 W
我正在使用 Qt(带有 Qt 创建者的精美浏览器示例)使用此代码创建网页的屏幕截图(从 here 获取并转换): QImage *image = new QImage(view->page()->ma
我想重写 QWebPage 类的 userAgentForUrl 函数,但我做错了什么,用户代理仍然是默认的。 #! /usr/bin/env python2.7 from PyQt4.QtCore
我想要 QWebPage 来加载 html 页面(因为我在控制台应用程序中,我不能使用 QWebView)。 当我这样做时: bool webview::load(Arguments *args) {
我在主线程中创建了一个 QWebPage(您不能在其他任何地方创建它)。我想使用 Qt 4.6 中引入的 QWebElement API 来操作此页面,但在一个单独的线程中。这样该线程将获取对页面的引
我已经创建了一个 Qt GUI 应用程序,但我没有触及任何有关 GUI 的内容。我修改了mainwindow.cpp和工程文件。 主窗口.cpp: #include "mainwindow.h" #i
我需要能够对 QWebPage 中的焦点变化使用react。我使用了 microFocusChanged() 信号,它给了我几乎理想的行为,但无论如何我不知道如何知道选择了哪个元素。当页面上的任何可编
如何处理“在新窗口中打开链接”以打开新的 QWebPage而不是新窗口,将之前的 QWebPage 保存在堆栈中,并使用 QWebView::setPage() 显示新窗口? 我是 Qt(甚至 C++
我想在非 GUI Qt 应用程序中使用 QWebPage。我的意思是我根本不想与窗口服务器通信。不过,使用 QtGui 不是问题。 QWebPage 在内部创建一些 QWidget 实例。因此,使用
我目前正在将此信号与处理点击的函数连接起来。例如: QtCore.QObject.connect(self.ui.webView, QtCore.SIGNAL("linkClicked (const
我正在使用 Qt 5.0 + mingw 构建我的应用程序,我想使用“webkitwidgets”模块。我在 .pro 文件中添加 QT += webkitwidgets 然后在我的代码中我创建了一个
我是 Python 新手,我试图理解为什么会出现以下错误: Traceback (most recent call last): File "WebScraper.py", line 10, in
我使用 PyQt4 创建了一个 QWebView,然后使用其 setHtml() 方法加载它。 HTML 在大多数方面都能正确显示,但始终使用默认的无衬线字体。 当相同的 HTML 纯文本被外部浏览器
我正在使用 Qt 的 QWebPage 呈现一个页面,该页面使用 javascript 动态更新其内容 - 因此仅下载静态版本页面(例如 urllib2)的库将无法工作。 我的问题是,当我呈现第二个页
我用 QWebPage 下载网页及其所有资源。同时,我想掌握 Qt 在此过程中下载的原始数据。通过从 QNetworkReply 读取数据来完成此操作在 void QNetworkAccessMana
我想在完全加载时将页面内容保存到图像,但有时我得到的输出栅格未完全呈现。 import sys import signal import os from PyQt4.QtCore import * f
我是一名优秀的程序员,十分优秀!