如何修复我的Table Viewcontroller上的时间延迟?

问题描述 投票:0回答:1

我创建了一个笔记应用程序。我创建了一个记事本应用程序,它的 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.
  }
}

ios swift iphone uitableview viewcontroller
1个回答
0
投票

试着把你的NotizenViewControllerArchive上的代码从viewDidAppear移到viewWillAppear或viewDidLoad.viewDidAppear里面的代码只有在视图已经在屏幕上为用户显示后才会执行(所以才有这个名字

© www.soinside.com 2019 - 2024. All rights reserved.