PySide 将 HTML 中的按钮连接到 PySide 插槽
PySide connect a button in HTML to a PySide slot
是否可以在 PySide 中使用 Web 类 之一来加载包含按钮的本地 html/JS 文件,并将这些按钮连接到 PySide 插槽?
您可以使用 QtWebKit 将 QObject 导出到 JavaScript 上下文,然后从 JavaScript 投射信号,如下例所示:
├── index.html
└── main.py
main.py
import os
from PySide import QtCore, QtGui, QtWebKit
CURRENT_DIR = os.path.dirname(os.path.realpath(__file__))
class ClickListener(QtCore.QObject):
clicked = QtCore.pyqtSignal()
if __name__ == "__main__":
import sys
app = QtGui.QApplication(sys.argv)
listener = ClickListener()
listener.clicked.connect(lambda: print("clicked"))
filename = os.path.join(CURRENT_DIR, "index.html")
w = QtWebKit.QWebView()
w.page().mainFrame().addToJavaScriptWindowObject("qt_clicked_listener", listener)
w.load(QtCore.QUrl.fromLocalFile(filename))
w.show()
sys.exit(app.exec_())
index.html
<!DOCTYPE html>
<html>
<body>
<button id="myBtn">Click me</button>
<script>
document.getElementById("myBtn").addEventListener("click", function() {
qt_clicked_listener.clicked();
});
</script>
</body>
</html>
是否可以在 PySide 中使用 Web 类 之一来加载包含按钮的本地 html/JS 文件,并将这些按钮连接到 PySide 插槽?
您可以使用 QtWebKit 将 QObject 导出到 JavaScript 上下文,然后从 JavaScript 投射信号,如下例所示:
├── index.html
└── main.py
main.py
import os
from PySide import QtCore, QtGui, QtWebKit
CURRENT_DIR = os.path.dirname(os.path.realpath(__file__))
class ClickListener(QtCore.QObject):
clicked = QtCore.pyqtSignal()
if __name__ == "__main__":
import sys
app = QtGui.QApplication(sys.argv)
listener = ClickListener()
listener.clicked.connect(lambda: print("clicked"))
filename = os.path.join(CURRENT_DIR, "index.html")
w = QtWebKit.QWebView()
w.page().mainFrame().addToJavaScriptWindowObject("qt_clicked_listener", listener)
w.load(QtCore.QUrl.fromLocalFile(filename))
w.show()
sys.exit(app.exec_())
index.html
<!DOCTYPE html>
<html>
<body>
<button id="myBtn">Click me</button>
<script>
document.getElementById("myBtn").addEventListener("click", function() {
qt_clicked_listener.clicked();
});
</script>
</body>
</html>