我创建了一个笔记应用程序。我创建了一个记事本应用程序,它的 NotizenViewControllerArchive
保存笔记,并与 NotizenViewControllerAdd
你能不能添加新的笔记。
有第三个Viewcontroller,在这个上面我可以访问其他两个视图,但是当我从第三个Viewcontroller切换(用一个按钮)到 NotizenViewControllerArchive
有一个时间延迟,一个短暂的时刻谁我不能看到我的笔记,我怎么能解决这个问题,所以笔记立即显示?
我尝试了很长一段时间来解决它,但我不知道如何,我把整个代码,因为我不知道问题出在哪里。谢谢你的帮助
NotizenViewControllerArchive(通知栏视图控制器档案)。
import UIKit
class NotizenViewControllerArchive: UIViewController, UITableViewDelegate, UITableViewDataSource {
@IBOutlet weak var table: UITableView!
var items:[String] = []
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return items.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = UITableViewCell(style: UITableViewCell.CellStyle.default, reuseIdentifier: "Cell")
let backgroundView = UIView()
backgroundView.backgroundColor = UIColor.init(red: 48/255, green: 173/255, blue: 99/255, alpha: 1)
cell.selectedBackgroundView = backgroundView
cell.textLabel?.text = items[indexPath.row]
return cell
}
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
}
override func viewDidAppear(_ animated: Bool) {
let itemObject = UserDefaults.standard.object(forKey: "items")
if let tempItems = itemObject as? [String] {
items = tempItems
}
table.reloadData()
}
func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCell.EditingStyle, forRowAt indexPath: IndexPath) {
if editingStyle == UITableViewCell.EditingStyle.delete {
items.remove(at: indexPath.row)
tableView.reloadData()
UserDefaults.standard.set(items, forKey: "items")
}
}
}
NotizenViewControllerAdd
import UIKit
class NotizenViewControllerAdd: UIViewController, UITextFieldDelegate {
@IBOutlet weak var itemTextField: UITextField!
@IBAction func ad(_ sender: UIButton) {
let itemObject = UserDefaults.standard.object(forKey: "items")
var items:[String]
if let tempItems = itemObject as? [String] {
items = tempItems
items.append(itemTextField.text!)
print("items")
} else {
items = [itemTextField.text!]
}
UserDefaults.standard.set(items, forKey: "items")
itemTextField.text = ""
}
override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
self.view.endEditing(true)
}
func textFieldShouldReturn(_ textField: UITextField) -> Bool {
return true
}
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
}
}
试着把你的NotizenViewControllerArchive上的代码从viewDidAppear移到viewWillAppear或viewDidLoad.viewDidAppear里面的代码只有在视图已经在屏幕上为用户显示后才会执行(所以才有这个名字