gpt4 book ai didi

ios - 自定义 UITableViewCell 中的 UITextField 意外发现为 nil

转载 作者:行者123 更新时间:2023-11-28 06:02:56 25 4
gpt4 key购买 nike

我有一个 TableView,里面有一个自定义单元格,里面有一个 TextField,不幸的是我得到了一个 Thread 1: Fatal error: Unexpectedly found nil while unwrapping an Optional我使用它们时的值(按回车键或触摸文本字段外的屏幕以退出占位符)。

这是我的代码:

class WalletTableViewController: UIViewController, UITextFieldDelegate {

var cryptosArray: [Cryptos] = []

override func viewDidLoad() {
super.viewDidLoad()

tableView.delegate = self

loadCryptoArray()
}

func loadCryptoArray() {

if UserDefaults.standard.object(forKey: "cryptosArray") != nil {
if let decoded = UserDefaults.standard.object(forKey: "cryptosArray") as? Data? {
let decodedCryptoArray = NSKeyedUnarchiver.unarchiveObject(with: decoded!) as! [Cryptos]
cryptosArray = decodedCryptoArray
}
}
}

}

TableView 扩展:

extension WalletTableViewController: UITableViewDelegate, UITableViewDataSource {

func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return cryptosArray.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

let crypto = cryptosArray[indexPath.row]

let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) as! WalletTableViewCell
cell.setCrypto(crypto: crypto)
cell.delegate = self
cell.amountTextField.delegate = self

return cell
}
func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
return 85
}
func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
if editingStyle == .delete {
cryptosArray.remove(at: indexPath.row)
tableView.deleteRows(at: [indexPath], with: .fade)

let userDefaults = UserDefaults.standard
let encodedData : Data = NSKeyedArchiver.archivedData(withRootObject: cryptosArray)
userDefaults.set(encodedData, forKey: "cryptosArray")
userDefaults.synchronize()
}
}
}

这是 TextField 的委托(delegate)函数:

extension WalletTableViewController: CryptoCellDelegate {
func cellAmountEntered(_ sender: Any) {
if WalletTableViewCell().amountTextField.text == "" {
return
}
let str = WalletTableViewCell().amountTextField.text

let formatter = NumberFormatter()
formatter.locale = Locale(identifier: "en_US")
let dNumber = formatter.number(from: str!)
let nDouble = dNumber!
let eNumber = Double(truncating: nDouble)

WalletTableViewCell().amountLabel.text = String(format:"%.8f", eNumber)

UserDefaults.standard.set(WalletTableViewCell().amountLabel.text, forKey: "bitcoinAmount")
WalletTableViewCell().amountTextField.text = ""

}
}

自定义单元格文件:

protocol CryptoCellDelegate {
func cellAmountEntered(_ sender: Any)
}

class WalletTableViewCell: UITableViewCell {

@IBOutlet weak var cryptoNameLabel: UILabel!
@IBOutlet weak var amountLabel: UILabel!

@IBOutlet weak var amountTextField: UITextField!

var cryptoItem: Crypto!
var delegate: CryptoCellDelegate?

func setCrypto(crypto: Cryptos) {

cryptoNameLabel.text = crypto.name
}

@IBAction func amountTextFieldEntered(_ sender: Any) {
delegate?.cellAmountEntered((Any).self)
}

}

TableView 具有用户想要的任意多个单元格,因此这取决于创建单元格的对象的 array

我想我在某处遇到了delegate 问题?我对 UITableView 很陌生,所以这是一个很大的挑战,请原谅任何愚蠢的错误 :)

PS:我试图通过删除 keyboard 函数和不相关的东西来保持代码简短,如果您需要其他东西,请告诉我。

最佳答案

在任何使用 WalletTableViewCell() 的地方,您都在创建 WalletTableViewCell 的新实例。发生崩溃是因为您正在以编程方式创建它,而 WalletTableViewCell 是使用 Storyboard设计的,并且由于您没有使用 Storyboard实例化它,所以 @IBOutlet 尚未设置,因此是 nil

更新

尝试使用它来修复它。将 CryptoCellDelegate 更新为:

protocol CryptoCellDelegate {
func cellAmountEntered(_ walletTableViewCell: WalletTableViewCell)
}

然后在 WalletTableViewCell 中将 amountTextFieldEntered 更新为:

@IBAction func amountTextFieldEntered(_ sender: Any) {
delegate?.cellAmountEntered(self)
}

最后更新委托(delegate)实现:

extension WalletTableViewController: CryptoCellDelegate {
func cellAmountEntered(_ walletTableViewCell: WalletTableViewCell) {
// now you can use walletTableViewCell to access the cell that called the delegate method
if walletTableViewCell.amountTextField.text == "" {
return
}
let str = walletTableViewCell.amountTextField.text

let formatter = NumberFormatter()
formatter.locale = Locale(identifier: "en_US")
let dNumber = formatter.number(from: str!)
let nDouble = dNumber!
let eNumber = Double(truncating: nDouble)

walletTableViewCell.amountLabel.text = String(format:"%.8f", eNumber)

UserDefaults.standard.set(walletTableViewCell.amountLabel.text, forKey: "bitcoinAmount")
walletTableViewCell.amountTextField.text = ""

}
}

关于ios - 自定义 UITableViewCell 中的 UITextField 意外发现为 nil,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49047174/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com