在HTML中的下拉框中怎样实现超连接?

给你个例子自己改吧:

<SELECT name="select" οnchange="window.open(this.options[this.selectedIndex].value,target='_self')">
<OPTION value='file1.htm' selected>网址1</OPTION>
<OPTION value='file2.htm'>网址2</OPTION>
<OPTION value='file3.htm'>网址3</OPTION>
</SELECT>

有多个链接就把<OPTION value='file3.htm'>网址3</OPTION>这行内容多复制几次改一下网址就行了。

上面代码是链接在当前窗口打开,要找开新窗口把target='_self'改为target='_blank'就行了。
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在QAbstractTableModel的一行添加下拉框,您需要在QTableView使用QItemDelegate。 QItemDelegate是一个用于呈现和编辑单元格数据的委托类。您可以使用QComboBox作为下拉框编辑器,并在QItemDelegate实现createEditor和setEditorData等方法来创建和设置下拉框。 下面是一个简单的示例: ```python from PyQt5.QtCore import Qt, QModelIndex from PyQt5.QtWidgets import QComboBox, QItemDelegate class ComboBoxDelegate(QItemDelegate): def __init__(self, items): super().__init__() self.items = items def createEditor(self, parent, option, index): editor = QComboBox(parent) editor.addItems(self.items) return editor def setEditorData(self, editor, index): value = index.model().data(index, Qt.EditRole) editor.setCurrentText(value) def setModelData(self, editor, model, index): value = editor.currentText() model.setData(index, value, Qt.EditRole) ``` 在上面的示例,我们创建了一个名为ComboBoxDelegate的QItemDelegate子类,它使用给定的项目列表初始化一个QComboBox编辑器。createEditor方法返回一个QComboBox实例,setEditorData方法从模型获取当前值并将其设置为下拉框的当前文本,setModelData方法将所选项目作为模型的新值。 现在,您可以将ComboBoxDelegate实例分配给QTableView的某一列,如下所示: ```python from PyQt5.QtCore import Qt, QVariant, QAbstractTableModel from PyQt5.QtWidgets import QApplication, QTableView class MyTableModel(QAbstractTableModel): def __init__(self, data): super().__init__() self._data = data def rowCount(self, parent=QModelIndex()): return len(self._data) def columnCount(self, parent=QModelIndex()): return len(self._data[0]) def data(self, index, role=Qt.DisplayRole): if role == Qt.DisplayRole: return QVariant(self._data[index.row()][index.column()]) elif role == Qt.EditRole: return QVariant(self._data[index.row()][index.column()]) return QVariant() if __name__ == '__main__': app = QApplication([]) data = [['Item 1', 'Value 1'], ['Item 2', 'Value 2'], ['Item 3', 'Value 3']] model = MyTableModel(data) view = QTableView() delegate = ComboBoxDelegate(['Value 1', 'Value 2', 'Value 3']) view.setItemDelegateForColumn(1, delegate) view.setModel(model) view.show() app.exec_() ``` 在上面的示例,我们创建了一个名为MyTableModel的QAbstractTableModel子类,它使用给定的数据列表初始化。然后,我们创建了一个QTableView实例,并使用setItemDelegateForColumn方法将ComboBoxDelegate实例分配给第二列。最后,我们将模型设置为视图的模型,并显示它。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lxw1844912514

你的打赏就是对我最大的鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值