• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

iOS - 在展开可选值时意外发现 nil

[复制链接]
菜鸟教程小白 发表于 2022-12-12 18:49:29 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

请帮忙,在我决定创建 loadData 函数并将它放在 if 子句中之前,代码已经工作了。所有其他意外发现的 nil 修复都涉及更改单元格声明的内容,我已经尝试过了,我觉得这个问题是由我放置 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","latypus"]

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 {

fatal error :在展开可选值时意外发现 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 子句中之前,代码已经工作了。所有其他意外发现的 nil 修复都涉及更改单元格声明的内容,我已经尝试过了,我觉得这个问题是由我放置 loadData 的位置引起的。

谢谢。



Best Answer-推荐答案


我改写了两行代码,让你的代码更稳定,解决bug:

let cell = self.table.dequeueReusableCellWithIdentifier("cell", forIndexPath: indexPath)
cell.textLabel?.text = self.items[indexPath.row]

关于iOS - 在展开可选值时意外发现 nil,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35929751/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap