请帮助,代码在我决定创建loadData函数并将其放在if子句中之前工作。所有其他意外发现的零修复涉及更改单元格声明的内容,我已经尝试过了,我觉得这个问题是由我放置loadData的地方引起的。
谢谢。
import UIKit
class GroupsTableViewController: UITableViewController /* UITableViewDataSource, UITableViewDelegate */ {
let APP_ID = "IGNORE"
let SECRET_KEY = "IGNORE"
let VERSION_NUM = "v1"
var backendless = Backendless.sharedInstance()
@IBOutlet weak var table: UITableView!
var items=["Dog","Cat","Cow","Platypus"]
override func viewDidLoad() {
super.viewDidLoad()
// Uncomment the following line to preserve selection between presentations
// self.clearsSelectionOnViewWillAppear = false
// Uncomment the following line to display an Edit button in the navigation bar for this view controller.
// self.navigationItem.rightBarButtonItem = self.editButtonItem()
}
override func viewDidAppear(animated: Bool) {
super.viewDidAppear(animated)
backendless.initApp(APP_ID, secret:SECRET_KEY, version:VERSION_NUM)
self.backendless.userService.getPersistentUser()
let user = self.backendless.userService.currentUser
if (user != nil) {
self.loadData()
} else {
Utilities.loginUser(self)
}
self.tableView.rowHeight = UITableViewAutomaticDimension;
self.tableView.estimatedRowHeight = 120.0;
}
func loadData() {
self.table.registerClass(UITableViewCell.self, forCellReuseIdentifier: "cell")
self.table.dataSource = self
self.table.delegate = self
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
// MARK: - Table view data source
override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
// #warning Incomplete implementation, return the number of sections
return 1
}
override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
// #warning Incomplete implementation, return the number of rows
return items.count
}
override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
致命错误:在解包可选值时意外发现nil:
let cell = self.table.dequeueReusableCellWithIdentifier("cell")! as UITableViewCell
cell.textLabel!.text = self.items[indexPath.row]
// Configure the cell...
return cell
}
override func tableView(tableView: UITableView, didDeselectRowAtIndexPath indexPath: NSIndexPath) {
print("You tapped on cell # \(indexPath.row)")
}
}
请帮助,代码在我决定创建loadData函数并将其放在if子句中之前工作。所有其他意外发现的零修复涉及更改单元格声明的内容,我已经尝试过了,我觉得这个问题是由我放置loadData的地方引起的。
谢谢。
答案 0 :(得分:2)
我重写两行以使您的代码更稳定并解决错误:
let cell = self.table.dequeueReusableCellWithIdentifier("cell", forIndexPath: indexPath)
cell.textLabel?.text = self.items[indexPath.row]