АЧ
Алексей Чепрасов27 червня 2016 р. 12:58
Передача данных из комбобокса в строку ввода в QML
Всем привет. Нужно передать выбранный элемент комбобокса в строку ввода текста, к примеру в “наименование товара”
Код файла с таблицей
import QtQuick 2.3 import QtQuick.Window 2.2 import QtQuick.Controls 1.4 import QtQuick 2.5 import QtQuick.Layouts 1.1 import QtQuick.Dialogs 1.2 ApplicationWindow { id:table1 visible: false width: 1700 height: 700 title: qsTr("Панель администратора") Text{ x:300 text: "" } Button { id: button text: qsTr("Выход") anchors.top: parent.top anchors.topMargin: 5 anchors.left: parent.left anchors.leftMargin: 5 onClicked: {table1.visible=false } } /* TabView, в первой вкладке которого находится кнопка, * по нажатию кнопки которой из изменится текст в первой кнопке */ TabView { id: tabView anchors.top: button.bottom anchors.topMargin: 5 anchors.left: parent.left anchors.right: parent.right anchors.bottom: parent.bottom Tab { id: tab1 title: qsTr("Товары") component: Item { id: rect1 } Rectangle{visible: true width: 1600 height: 480 // Слой с TaxtField`ами и Button для занесения записей в базу данных RowLayout { id: rowLayout anchors.top: parent.top anchors.left: parent.left anchors.right: parent.right anchors.margins: 5 spacing: 10 Text {text: qsTr("Наименование товара")} TextField {id: fnameField } Text {text: qsTr("Категория")} TextField {id: kategoryField} Text {text: qsTr("Прибыло")} TextField { id: snameField} Text {text: qsTr("Убыло")} TextField { id: ubylField} Text {text: qsTr("Номер стеллажа")} TextField {id: nikField} Text {text: qsTr("Номер полки")} TextField {id: numberpolkField} Button { id: pusto text: qsTr("Добавить") // Вносим новую запись в базу данных MouseArea{ anchors.fill: parent onClicked: { if (fnameField.text=="" || snameField.text=="" || ubylField.text=="" || nikField.text=="" || numberpolkField.text=="" || kategoryField.text=="") { contextMenu2.popup() } if(kategoryField.text=="Овощи" ||kategoryField.text=="овощи"||kategoryField.text=="Фрукты"||kategoryField.text=="фрукты") { database.inserIntoTable( fnameField.text , kategoryField.text, snameField.text, ubylField.text, nikField.text, numberpolkField.text) myModel.updateModel() // И обновляем модель данных с новой записью } else contextMenu3.popup() } } } Button { text: qsTr("Экспорт в Excel") // Запускаем экспорт onClicked: { myModel.exportCSV() } } } TableView { id: tableView anchors.top: rowLayout.bottom anchors.left: parent.left anchors.right: parent.right anchors.bottom: parent.bottom anchors.margins: 5 TableViewColumn { role: "date" title: "Дата" } TableViewColumn { role: "time" title: "Время" } TableViewColumn { role: "fname" title: "Наименование товара" } TableViewColumn { role: "kategory" title: "Категория" } TableViewColumn { role: "sname" title: "Прибыло" } TableViewColumn { role: "ubyl" title: "Убыло" } TableViewColumn { role: "nik" title: "Номер стеллажа" } TableViewColumn { role: "numberpolk" title: "Номер полки" } model: myModel // Настройка строки в TableView для перехавата левого клика мыши rowDelegate: Rectangle { anchors.fill: parent color: styleData.selected ? 'skyblue' : (styleData.alternate ? 'whitesmoke' : 'white'); MouseArea { anchors.fill: parent acceptedButtons: Qt.RightButton | Qt.LeftButton onClicked: { tableView.selection.clear() tableView.selection.select(styleData.row) tableView.currentRow = styleData.row tableView.focus = true switch(mouse.button) { case Qt.RightButton: contextMenu.popup() // Вызываем контексткное меню break default: break } } } } } // Контекстно меню предлагает удаление строки из базы данных Menu { id: contextMenu MenuItem { text: qsTr("Удалить") onTriggered: { /* Вызываем диалоговое окно, * которое уточнит намерение удалить строку из базы данных * */ dialogDelete.open() } } } // Диалог подтверждения удаления строки из базы данных MessageDialog { id: dialogDelete title: qsTr("Удаление записи") text: qsTr("Подтвердите удаление записи со склада") icon: StandardIcon.Warning standardButtons: StandardButton.Ok | StandardButton.Cancel // При положительном ответе ... onAccepted: { /* ... удаляем строку по id, * который забираем из модели данных * по номеру строки в представлении * */ database.removeRecord(myModel.getId(tableView.currentRow)) myModel.updateModel(); // Обновляем модель данных } } //Всплывающее окно если строка ввода текста пустая Menu { id: contextMenu2 MenuItem { text: qsTr("Что - то пошло не так :С") onTriggered: { dialogNULL.open() } } } // Диалог подтверждения удаления строки из базы данных MessageDialog { id: dialogNULL title: qsTr("Одна или несколько строк не заполнены") text: qsTr("Проверьте, все ли строки заполнены и добавте запись в таблицу") icon: StandardIcon.Warning standardButtons: StandardButton.Ok | StandardButton.Cancel // При положительном ответе ... onAccepted: { dialogNULL.visible=false } } Menu { id: contextMenu3 MenuItem { text: qsTr("Аяяй :С") onTriggered: { dialogOvosh.open() } } } MessageDialog { id: dialogOvosh title: qsTr("Склад овощей!!!") text: qsTr("На складе нельзя хранить что - то, кроме овощей и фруктов") icon: StandardIcon.Warning standardButtons: StandardButton.Ok | StandardButton.Cancel // При положительном ответе ... onAccepted: { dialogOvosh.visible=false } } ComboBox { x:100 y:300 editable: true model: ListModel { id: model ListElement { text: "Banana"; color: "Yellow" } ListElement { text: "Apple"; color: "Green" } ListElement { text: "Coconut"; color: "Brown" } } onAccepted: { if (find(currentText) === -1) { model.append({text: editText}) currentIndex = find(editText) fnameField.insert(currentIndex) } } } } } } }
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.Вам це подобається? Поділіться в соціальних мережах!
AD
- Akiv Doros
- 11 листопада 2024 р. 14:58
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:50бали,
- Рейтинг балів-4
m
- molni99
- 26 жовтня 2024 р. 01:37
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:80бали,
- Рейтинг балів4
m
- molni99
- 26 жовтня 2024 р. 01:29
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:20бали,
- Рейтинг балів-10
Останні коментарі
ИМ
Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Игорь Максимов22 листопада 2024 р. 11:51
Evgenii Legotckoi31 жовтня 2024 р. 14:37
Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь Максимов05 жовтня 2024 р. 07:51
QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Тепер обговоріть на форумі
Evgenii Legotckoi24 червня 2024 р. 15:11
t
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
tonypeachey115 листопада 2024 р. 06:04
NSProject04 червня 2022 р. 03:49
IscanderChe31 жовтня 2024 р. 15:43
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
Добрый день.
Можно реализовать это через обработчик сигнала комбобокса onCurrentTextChanged, то есть
Но учитывая, что каждый элемент модели состоит из двух полей, то правильнее будет сделать следующим образом.
для улучшения внешнего вида у TextField добавляем параметр visible: false
Тогда уж лучше вообще избавиться от этого лишнего элемента.
Ведь можно же забирать данные из комбобокса и передавать их куда следует.