轻扫时删除,当您轻扫任何一个时,将删除列表中的第一项

时间:2019-03-28 14:28:27

标签: xcode swift3 sqlite

每次我在表格视图中滑动项目并将其删除时,它都会删除列表中的第一个项目,而不是我滑动的项目。我尝试了不同的方法,但仍在执行相同的操作

这是我的视图控制器功能,在其中滑动并调用delete方法。

func tableView(_ tableView: UITableView, leadingSwipeActionsConfigurationForRowAt indexPath: IndexPath) -> UISwipeActionsConfiguration? 
{

let modifyAction = UIContextualAction(style: .normal, title: "Modify", handler:
        { ac, view, success in
            var stmt: OpaquePointer?

            let deleteStatementStirng = "SELECT * FROM ShoppingList"
            if sqlite3_prepare(self.db, deleteStatementStirng, -1, &stmt, nil) != SQLITE_OK
            {
                print("error preparing delete")
            }

            if sqlite3_step(stmt) == SQLITE_ROW {
                let id = sqlite3_column_int(stmt, 0)
                self.deleteRow(itemId: Int32(id))
            }
            success(true)
        }
    )

    modifyAction.backgroundColor = .red
    return UISwipeActionsConfiguration(actions: [modifyAction])
}

还有我的删除功能:

func deleteRow(itemId: Int32){
        let deleteStatementStirng = "DELETE FROM ShoppingList WHERE id = \(itemId)"

        var deleteStatement: OpaquePointer?

        if sqlite3_prepare(db, deleteStatementStirng, -1, &deleteStatement, nil) == SQLITE_OK{

            if sqlite3_step(deleteStatement) == SQLITE_DONE {
                print("Successfully deleted row.")
            } else {
                print("Could not delete row.")
            }
        } else {
            print("DELETE statement could not be prepared")
        }

        sqlite3_finalize(deleteStatement)
        readValues()

    }

预期结果是从列表中删除项目

2 个答案:

答案 0 :(得分:0)

您应该使用

  

indexPath.row

获取要对其执行操作的行的实际索引。

答案 1 :(得分:0)

只需使用以下命令更新您的ModifyAction代码:(添加id时添加indexPath.row而不是0)

let modifyAction = UIContextualAction(style: .normal, title: "Modify", handler:
    { ac, view, success in
        var stmt: OpaquePointer?

        let deleteStatementStirng = "SELECT * FROM ShoppingList"
        if sqlite3_prepare(self.db, deleteStatementStirng, -1, &stmt, nil) != SQLITE_OK
        {
            print("error preparing delete")
        }

        if sqlite3_step(stmt) == SQLITE_ROW {
            let id = sqlite3_column_int(stmt, indexPath.row)
            self.deleteRow(itemId: Int32(id))
        }
        success(true)
    }
)