Dec. 21, 2016, 7:21 a.m.

Удаление записи из БД (Qml ListView)

ListView, QML

На основе урока “База данных SQLite и работа с ней в QML Qt” делаю проект с представлением данных в ListView. Уперся в удалении записи из списка, точнее в получении индекса(Id) выбранного элемента. При выборе (подсветке) элемента кликом мыши значение view.currentIndex соответствует выбранному, но при передаче в getId удаляется всегда первый элемент. В чем моя ошибка? Поправьте пожалуйста.

import QtQuick 2.7
import QtQuick.Controls 2.0
import QtQuick.Layouts 1.0
Item {
    id: item1    
    RowLayout {
        anchors.fill: parent
        Rectangle {
            id: rec1
            z:1
            anchors.left: parent.left            
            anchors.top: parent.top            
            height: item1.height
            width: 300
            color: "white"
            border.width: 2
            border.color: "#353637"
            Row{
                id: row1
                anchors.left: rec1.left
                anchors.leftMargin: 5
                anchors.right: rec1.right
                anchors.rightMargin: 5
                anchors.top: rec1.top
                anchors.topMargin: 5
                height: 40
                spacing: 5
                TextField {
                    id: tf1
                    width: 200
                    placeholderText: "Идентификатор"
                    font.pixelSize: 20
                }
                Button {
                    width: rec1.width - tf1.width - 15
                    highlighted: true
                    Text {
                        id: name1
                        text: qsTr("Поиск")
                        font.family: "Arial"
                        font.bold: true
                        color: "white"
                        font.pixelSize: 20
                        anchors.horizontalCenter: parent.horizontalCenter
                        anchors.verticalCenter: parent.verticalCenter
                    }
                }
            }
            /* Область списка */
            Rectangle {
                id: rec2
                color: "white"
                border.width: 1
                border.color: "#353637"
                width: rec1.width - 10
                anchors.left: rec1.left
                anchors.leftMargin: 5
                anchors.top: row1.bottom
                anchors.topMargin: 5
                anchors.bottom: row2.top
                anchors.bottomMargin: 5
                Flickable {
                    id: view
                    width: list.width
                    anchors.fill: parent
                    contentWidth: list.width
                    ListView {
                        id: list
                        width: rec2.width
                        height: rec2.height
                        anchors.fill: parent
                        model: QueryModel1
                        delegate: numberDelegate
                        focus: true
                        headerPositioning: ListView.OverlayHeader
                        spacing: 1
                        highlight: Rectangle {
                            id: svet
                                    z: -3
                                    y: list.currentItem.y;
                                    Behavior on y { SpringAnimation { spring: 2; damping: 0.1 } }
                                    color: "#1E90FF"
                        }
                                highlightFollowsCurrentItem: true
                                highlightMoveDuration : 100
            }
                    Component {
                        id: numberDelegate
                        RowLayout {
                            id: wrapper
                            property int number: index
                            width: ListView.view.width
                            height: 40
                            //anchors.topMargin: 300
                            z: -1
                            property var view: ListView.view
                            property var isCurrent: ListView.isCurrentItem
                            Rectangle {
                                id: rec3
                                MouseArea {
                                    id: mouse
                                    anchors.fill: parent
                                    onClicked: view.currentIndex = model.index                                                }
                                z: -4
                                width: parent.width
                                height: 40
                                color: "transparent"
                                border.color: "#353637"
                                Text {
                                    anchors.centerIn: parent
                                    font.pixelSize: 20
                                    text: Identifikator
                                }
                                Text {
                                    id: text1
                                    font.pixelSize: 10
                                    text: view.currentIndex
                                }
                            }
                        }
                    }
                transitions: Transition {
                    NumberAnimation { properties: "opacity"; duration: 400 }
                }
            }
            }
            Row {
                id: row2
                anchors.left: rec1.left
                anchors.leftMargin: 5
                anchors.right: rec1.right
                anchors.rightMargin: 5
                anchors.bottom: rec1.bottom
                anchors.bottomMargin: 5
                height: 40
                spacing: 5
                Button {                    
                    highlighted: true
                    width: row2.width / 3 - 10 / 3
                    Text {
                        id: name2
                        text: qsTr("Создать")
                        font.family: "Arial"
                        font.bold: true
                        color: "white"
                        font.pixelSize: 12
                        anchors.horizontalCenter: parent.horizontalCenter
                        anchors.verticalCenter: parent.verticalCenter
                    }
                    onClicked: {
                        var component = Qt.createComponent("BazaOborudovaniaCreat.qml")
                        var window    = component.createObject(rec0)
                        window.show()
                    }
                }
                Button {                    
                    highlighted: true
                    width: row2.width / 3 - 10 / 3
                    Text {
                        id: name3
                        text: qsTr("Редактировать")
                        font.family: "Arial"
                        font.bold: true
                        color: "white"
                        font.pixelSize: 12
                        anchors.horizontalCenter: parent.horizontalCenter
                        anchors.verticalCenter: parent.verticalCenter
                    }
                }
                Button {                    
                    highlighted: true
                    width: row2.width / 3 - 10 / 3
                    Text {
                        id: name4
                        text: qsTr("Удалить")
                        font.family: "Arial"
                        font.bold: true
                        color: "white"
                        font.pixelSize: 12
                        anchors.horizontalCenter: parent.horizontalCenter
                        anchors.verticalCenter: parent.verticalCenter
                    }                    
                    onClicked: {
                        database.removeRecord(QueryModel1.getId(view.currentIndex)) // Почему-то удаляется первый элемент списка
                        QueryModel1.updateModel();
                    }
                }
            }
        }
Rectangle {
    id: rec0
    anchors.left: rec1.right
    anchors.top: parent.top
    anchors.right: parent.right
    height: item1.height
    SwipeView {
        id: swipeView
        anchors.fill: parent
        currentIndex: tabBar.currentIndex
        BazaOborudovania1 {
        }
        BazaOborudovania2 {
        }
        BazaOborudovania3 {
        }
        BazaOborudovania4 {
        }
    }
        TabBar {
        id: tabBar
        height: 40
        anchors.bottom: parent.bottom
        anchors.right: parent.right
        anchors.rightMargin: 0
        anchors.left: parent.left
        anchors.leftMargin: 0
        currentIndex: swipeView.currentIndex
        TabButton {
            text: qsTr("Общие данные")
            font.pixelSize: 15
            font.family: "Arial"
            font.bold: true
        }
        TabButton {
            text: qsTr("Критерии")
            font.pixelSize: 15
            font.family: "Arial"
            font.bold: true
        }
        TabButton {
            text: qsTr("Подшипники")
            font.pixelSize: 15
            font.family: "Arial"
            font.bold: true
        }
        TabButton {
            text: qsTr("История измерений")
            font.pixelSize: 15
            font.family: "Arial"
            font.bold: true
        }
    }
    }
    }
}

 

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.
3

Добрый день.
Что-то Вы, по-моему, перемудрили с делегатами и этим самым view.currentIndex…

Попробуйте вместо view.currentIdex использовать list.currentIndex

onClicked: {
    database.removeRecord(QueryModel1.getId(list.currentIndex)) 
    QueryModel1.updateModel();
}

 

Евгений, спасибо! Работает. Хотя я точно помню что c list.currentIndex тоже пробовал и удаляло только первый элемент. А сейчас работает. Наверное надо почаще чистить проект.
С QML вообще желательно почаще делать clean Project, а иногда и полностью удалять build.
А то как попало себя ведёт.

Comments

Only authorized users can post comments.
Please, Log in or Sign up
D
Aug. 16, 2019, 12:58 p.m.
Damir

C++ - Тест 003. Условия и циклы

  • Result:92points,
  • Rating points8
D
Aug. 16, 2019, 12:46 p.m.
Damir

C++ - Test 005. Structures and Classes

  • Result:75points,
  • Rating points2
u
Aug. 14, 2019, 2:55 p.m.
unrealproro

C++ - Test 005. Structures and Classes

  • Result:83points,
  • Rating points4
Last comments
b
Aug. 18, 2019, 6:09 a.m.
bbb116

cqtdeployer /home/aleks/CQtDeployer/bin/cqtdeployer: /lib/x86_64-linux-gnu/libc.so.6: version `GLIBC_2.25' not found (required by /home/aleks/CQtDeployer/lib/libQt5Core.so.5) linux mint …
D
Aug. 17, 2019, 9:04 a.m.
Damir

github ChekableTView Правой групповая смена значения при перетаскивании левой как обычно.
Aug. 16, 2019, 1:03 p.m.
Evgenij Legotskoj

Потому, что в минуте 60 секунд
Aug. 16, 2019, 12:16 p.m.
Dmitrij

а почему делитель 60000, а не 1000?
g
Aug. 14, 2019, 1:27 a.m.
grig_p

Спасибо большое. Получилось
Now discuss on the forum
Aug. 19, 2019, 12:40 a.m.
nayk1982

Программно можно проверить существование таблицы, получить список таблиц БД, получить список полей конкретной таблицы и т.д. Это все на совести программиста и если структура БД может меняться, т…
Aug. 15, 2019, 3:19 a.m.
Mihailll

Плюсы и qml отличаются, с++ логичней
Aug. 14, 2019, 8:20 a.m.
Evgenij Legotskoj

Да это не столько баги QML, сколько поведение JavaScript, который используется в нём. Из-за отсутствия строгой типизации получаем некоторые проблемы с преобразованием типов. в итоге, на первый в…
Aug. 14, 2019, 2:33 a.m.
BlinCT

Ошибка найдена) недосмотрел.
Aug. 13, 2019, 3:52 a.m.
Evgenij Legotskoj

Бери остаток от деления #include <QCoreApplication>#include <QTime>#include <QDebug>int main(int argc, char *argv[]){ QCoreApplication a(argc, argv); QTime time…
Looking for a Job?
14,000.00 руб. - 40,000.00 руб.
Разработчик Qt
Annino, Moscow Oblast, Russia
5,000.00 руб. - 15,000.00 руб.
Дизайнер
Moskovskiy, Moscow, Russia
25,000.00 руб. - 30,000.00 руб.
Разработчик Qt/C++
Barnaul, Altai Krai, Russia

For registered users on the site there is a minimum amount of advertising

EVILEG
About
Services
© EVILEG 2015-2019
Recommend hosting TIMEWEB