Я пытаюсь создать объектно-ориентированное приложение для iOS, и у меня возникают проблемы с вызовом перезагрузки таблицы (взаимодействие ui) из одного из моих файлов быстрых классов.iOS перезагрузка UITableView из класса Swift/объекта
Если я работаю без объектов и пишу все это в моем методе viewDidLoad интерфейса InterfaceController, все работает ... но не, если я помещаю это в классы.
Я использую асинхронный запрос для загрузки json-данных из веб-службы. После получения данных я использую эти данные в качестве источника данных для своего представления в таблице. Кажется, что tableview инициализируется после запуска без данных, поэтому необходимо вызвать reload() в представлении таблицы после завершения асинхронного запроса.
Так вот подробности:
Главная TableController
import UIKit;
class DeviceOverview: UITableViewController {
@IBOutlet var myTableView: UITableView!
var myDevices = Array<String>();
var myDevicesSection = NSMutableDictionary()
var deviceObjects = Array<NSDictionary>();
var mappingSectionIndex = Array<String>();
var sharedUserDefaults = NSUserDefaults(suiteName: "group.barz.fhem.SharingDefaults")
// THIS IS AN ATTEMPT TO give the class itself as PARAMETER
// ALSO TRIED TO USE myTableView (IBOutlet)
var fhem :FHEM = FHEM(tableview : self)
override func viewDidLoad() {
super.viewDidLoad()
}
override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
return self.fhem.sections.count
}
override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
var devicesInSection : Array<NSDictionary> = self.fhem.sections[self.fhem.mappingSectionIndex[section]] as! Array<NSDictionary>
return devicesInSection.count;
}
override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCellWithIdentifier("device", forIndexPath: indexPath) as! TableViewCell
let sectionName : String = fhem.mappingSectionIndex[indexPath.section]
if let devices : Array<NSDictionary> = self.fhem.sections.objectForKey(sectionName) as? Array<NSDictionary> {
let device = devices[indexPath.row]
var alias : NSString?;
if let attr : NSDictionary = device.objectForKey("ATTR") as? NSDictionary {
alias = attr.objectForKey("alias") as? String
}
if (alias != nil) {
cell.deviceLabel.text = alias as? String
}else{
if let deviceName : String = device.objectForKey("NAME") as? String {
cell.deviceLabel.text = deviceName
}
}
}
return cell
}
FHEM Класс
import UIKit
class FHEM: NSObject {
var devices : [NSDictionary]
var sections : NSMutableDictionary
var deviceNames : [String]
var mappingSectionIndex : [String]
var myTableViewController : DeviceOverview
init(tableview : DeviceOverview){
self.devices = Array<NSDictionary>()
self.sections = NSMutableDictionary()
self.deviceNames = Array<String>()
self.mappingSectionIndex = Array<String>()
self.myTableViewController = tableview
super.init()
let url = NSURL(string: "xyz");
var request = NSURLRequest(URL: url!);
NSURLConnection.sendAsynchronousRequest(request, queue: NSOperationQueue.mainQueue()) {
(response, data, error) in
if let jsonData: NSData? = data {
// do some great stuff
//
// this is an attempt to call the table view to reload
self.myTableViewController.myTableView.reloadData()
}
}
}
}
Он бросает ошибки компиляции, если я пытаюсь поставить переменную self
в конструктор моего конструктора
var fhem :FHEM = FHEM(tableview : self)
Он также не работает, если я пытаюсь поставить UITableView
непосредственно в конструктор
var fhem :FHEM = FHEM(tableview : myTableView)
Am Я шел по полному ложному пути, используя объекты и взаимодействующий с пользовательским интерфейсом?
Вы можете отправить уведомление для своей перезагрузки таблицы и добавить наблюдателя к контроллеру tableView для запуска reloadData –
Интерстинг, у вас есть пример? – Barzille