如何解决'QMainWindow' 对象没有属性 'addWidget'
我正在尝试制作一个具有多个屏幕的窗口,因此我尝试使用 PyQT5 的 Stacked Widget
容器。
为了尝试一下,我在设计器中做了一个简单的窗口,然后提取了它的代码。
但是,当我运行该代码时,出现错误 'QMainWindow' object has no attribute 'addWidget'
代码如下:
# -*- coding: utf-8 -*-
# Form implementation generated from reading ui file 'stack.ui'
#
# Created by: PyQt5 UI code generator 5.15.2
#
# WARNING: Any manual changes made to this file will be lost when pyuic5 is
# run again. Do not edit this file unless you kNow what you are doing.
from PyQt5 import QtCore,QtGui,QtWidgets
class Ui_StackedWidget(object):
def setupUi(self,StackedWidget):
StackedWidget.setobjectName("StackedWidget")
StackedWidget.resize(400,300)
self.page = QtWidgets.QWidget()
self.page.setobjectName("page")
self.label = QtWidgets.QLabel(self.page)
self.label.setGeometry(QtCore.QRect(130,80,111,51))
self.label.setobjectName("label")
StackedWidget.addDockWidget(self.page)
self.page_2 = QtWidgets.QWidget()
self.page_2.setobjectName("page_2")
self.label_2 = QtWidgets.QLabel(self.page_2)
self.label_2.setGeometry(QtCore.QRect(90,160,161,91))
self.label_2.setobjectName("label_2")
StackedWidget.addDockWidget(self.page_2)
StackedWidget.
self.retranslateUi(StackedWidget)
StackedWidget.setCurrentIndex(0)
QtCore.QMetaObject.connectSlotsByName(StackedWidget)
def retranslateUi(self,StackedWidget):
_translate = QtCore.QCoreApplication.translate
StackedWidget.setwindowTitle(_translate("StackedWidget","StackedWidget"))
self.label.setText(_translate("StackedWidget","first page"))
self.label_2.setText(_translate("StackedWidget","2nd page"))
if __name__ == "__main__":
import sys
app = QtWidgets.QApplication(sys.argv)
MainWindow = QtWidgets.QMainWindow()
ui = Ui_StackedWidget()
ui.setupUi(MainWindow)
MainWindow.show()
sys.exit(app.exec_())
解决方法
正如所有 pyuic 生成文件的标题中的警告所说,除非您真的知道自己在做什么,否则不应编辑它们。如果你知道你在做什么,你就不会编辑它们。
这是一种礼貌的说法:您必须永远编辑这些文件。
您不能尝试将 QMainWindow 与为 QStackedWidget 生成的文件一起使用,因为它们是完全不同的小部件,具有完全不同的目的和功能。
因为无论如何您可能会使用 QMainWindow,所以最好的解决方案是在 Designer 中创建一个 QMainWindow,并向其添加 QStackedWidget。只需确保您正确设置布局:如果堆叠小部件将成为“主小部件”,则将简单的垂直/水平盒装布局设置为主布局就足够了:右键单击堆叠小部件外的任意位置,然后从“布局”子菜单。
作为替代方案,如果您从 Designer 的新表单对话框中选择了该小部件,并且如果您还要正确遵循有关 using Designer 的准则,例如:
public function getUserdetails($id)
{
$userpost = DB::table('posts')->where('id',$id)->get();
return response()->json(['data' => $userpost]);
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。