it-roy-ru.com

Обновите определенную строку UITableView на основе Int в Swift

Я начинающий разработчик в Swift, и я создаю базовое приложение, которое включает в себя UITableView. Я хочу обновить определенную строку таблицы, используя:

self.tableView.reloadRowsAtIndexPaths(paths, withRowAnimation: UITableViewRowAnimation.none)

и я хочу, чтобы строка, которая будет обновлена, была от Int с именем rowNumber

Проблема в том, что я не знаю, как это сделать, и все темы, которые я искал, предназначены для Obj-C

Есть идеи?

65
BobRon

Вы можете создать NSIndexPath, используя номер строки и раздела, а затем перезагрузить его следующим образом:

let indexPath = NSIndexPath(forRow: rowNumber, inSection: 0)
tableView.reloadRowsAtIndexPaths([indexPath], withRowAnimation: UITableViewRowAnimation.Top)

В этом примере я предположил, что ваша таблица имеет только один раздел (т. Е. 0), но вы можете изменить это значение соответствующим образом.

Обновление для Swift 3.0:

let indexPath = IndexPath(item: rowNumber, section: 0)
tableView.reloadRows(at: [indexPath], with: .top)
159
Lyndsey Scott

Для мягкого анимационного решения:

Swift 3:

let indexPath = IndexPath(item: row, section: 0)
tableView.reloadRows(at: [indexPath], with: .fade)

Swift 2.x:

let indexPath = NSIndexPath(forRow: row, inSection: 0)
tableView.reloadRowsAtIndexPaths([indexPath], withRowAnimation: .Fade)

Это еще один способ защитить приложение от сбоев:

Swift 3:

let indexPath = IndexPath(item: row, section: 0)
if let visibleIndexPaths = tableView.indexPathsForVisibleRows?.index(of: indexPath as IndexPath) {
    if visibleIndexPaths != NSNotFound {
        tableView.reloadRows(at: [indexPath], with: .fade)
    }
}

Swift 2.x:

let indexPath = NSIndexPath(forRow: row, inSection: 0)
if let visibleIndexPaths = tableView.indexPathsForVisibleRows?.indexOf(indexPath) {
   if visibleIndexPaths != NSNotFound {
      tableView.reloadRowsAtIndexPaths([indexPath], withRowAnimation: .Fade)
   }
}
19
Alessandro Ornano

В Swift 3.0

let rowNumber: Int = 2
let sectionNumber: Int = 0

let indexPath = IndexPath(item: rowNumber, section: sectionNumber)

self.tableView.reloadRows(at: [indexPath], with: .automatic)

по умолчанию, если у вас есть только один раздел в TableView, то вы можете установить значение раздела 0.

2
jaiswal Rajan
let indexPathRow:Int = 0
let indexPosition = IndexPath(row: indexPathRow, section: 0)
tableView.reloadRows(at: [indexPosition], with: .none)
2
Sachin Rasane

Swift 4

let indexPathRow:Int = 0    
let indexPosition = IndexPath(row: indexPathRow, section: 0)
tableView.reloadRows(at: [indexPosition], with: .none)
1
Neha

Кроме того, если у вас есть section для таблицы, вы не должны пытаться найти все строки, которые хотите обновить, вы должны использовать разделы перезагрузки. Это простой и более сбалансированный процесс:

yourTableView.reloadSections(IndexSet, with: UITableViewRowAnimation)
0
Burcu K. Kutluay

Swift 4.2

    func reloadYourRows(name: <anyname>) {
    let row = <your array name>.index(of: <name passing in>)
    let reloadPath = IndexPath(row: row!, section: 0)
    tableView.reloadRows(at: [reloadPath], with: .middle)
    }
0
Legend_ 33

Я понимаю, что этот вопрос для Свифта, но вот Xamarin эквивалентный код принятого ответа, если кто-то заинтересован.

var indexPath = NSIndexPath.FromRowSection(rowIndex, 0);
tableView.ReloadRows(new NSIndexPath[] { indexPath }, UITableViewRowAnimation.Top);
0
wildbagel

Swift 4.1

используйте его при удалении строки, используя selectedTag of row. 

self.tableView.beginUpdates()

        self.yourArray.remove(at:  self.selectedTag)
        print(self.allGroups)

        let indexPath = NSIndexPath.init(row:  self.selectedTag, section: 0)

        self.tableView.deleteRows(at: [indexPath as IndexPath], with: .automatic)

        self.tableView.endUpdates()

        self.tableView.reloadRows(at: self.tableView.indexPathsForVisibleRows!, with: .automatic)
0
Rana Ali Waseem

Как насчет:

self.tableView.reloadRowsAtIndexPaths([NSIndexPath(rowNumber)], withRowAnimation: UITableViewRowAnimation.Top)
0
skyline75489