解决QML开发中ComboBox中一个已选择项没有清除的问题
Posted llguanli
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解决QML开发中ComboBox中一个已选择项没有清除的问题相关的知识,希望对你有一定的参考价值。
解决QML开发中ComboBox中一个已选择项没有清除的问题
近期使用QML开发一个项目。须要使用ComboBox进行显示。当进行一个操作时,须要向ComboBox加入一个元素,当进行另外一个操作时。须要清除ComboBox里面的元素。
可是在操作的过程中,出现了一个诡异的现象——ComboBox里面的已选择项并没有清除。
以下是程序的截图,能够看到。ComboBox中已选择项并没有删除。可是ComboBox中的候选项已经删除了。
我在QTCN上进行提问。后面再大家的努力下,最终把这个问题攻克了。
原来还须要一个操作:testCombo.currentIndex = -1。以下是我改动后的代码,代码能够非常好地执行。
import QtQuick 2.3 import QtQuick.Controls 1.2 ApplicationWindow { visible: true width: 640 height: 480 title: qsTr( "Clear CheckBox" ) menuBar: MenuBar { Menu { title: qsTr( "File") MenuItem { text: qsTr( "Exit" ) onTriggered: Qt.quit( ); } } } ListModel { id: testModel } ComboBox { id: testCombo anchors.centerIn: parent model: testModel textRole: "name" } property int margin: appendButton.height / 3 Button { id: appendButton anchors.right: testCombo.left anchors.verticalCenter: testCombo.verticalCenter anchors.margins: margin text: qsTr( "Append to list" ) onClicked: { testModel.append( { "name": "This is one" } ); testModel.append( { "name": "This is two" } ); testModel.append( { "name": "This is three" } ); testModel.append( { "name": "This is four" } ); testCombo.currentIndex = 0;// 修正Bug加入的 } } Button { anchors.left: testCombo.right anchors.verticalCenter: testCombo.verticalCenter anchors.margins: margin text: qsTr( "clear list" ) onClicked: { testCombo.currentIndex = -1;// 修正Bug加入的 testModel.clear( ); } } }
以上是关于解决QML开发中ComboBox中一个已选择项没有清除的问题的主要内容,如果未能解决你的问题,请参考以下文章
C#中 combox控件已绑定数据, 如何根据一个string类型字段 设置combox的选择项
在 QML 中填充 Combobox 模型时如何使用 csv 列表?
如果在另一个 Combobox 中选择,则隐藏特定的 Combobox 项