我正在开发基于日期的应用程序。我试图获取信息以从一个TableViewController传递到另一个。

这是一个基于通知的应用,可提醒用户今天有事情发生。因此,在发布之日,我希望它脱离发布列表,然后进入发布列表(因此,如果11月8日有内容出炉,则将在该日期移至发布列表中)。

我无法使其正常工作。我使用下面的代码,日期来去去去都没有发生任何事情,它仍在发布列表中显示。

以下是我在发布列表中使用的代码:

let startOfToday = Calendar.current.startOfDay(for: Date()) as NSDate
let predicate = NSPredicate(format: "release_date > %@", startOfToday)
fetchRequest.predicate = predicate


这是已发布列表上的代码:

let startOfToday = Calendar.current.startOfDay(for: Date()) as NSDate
let predicate = NSPredicate(format: "release_date < %@", startOfToday)
fetchRequest.predicate = predicate


这是FreshReleaseTableViewController的代码:

import UIKit
import CoreData
import UserNotifications

class FreshReleaseTableViewController: UITableViewController{
    var freshreleases = [Release_Date]()
    let dateFormatter = DateFormatter()

    override func viewDidLoad() {
        super.viewDidLoad()

        //create a new button
        let button = UIButton.init(type: .custom)
        //set image for button
        button.setImage(UIImage(named: "Mic App Logo.png"), for: UIControlState.normal)

        dateFormatter.dateStyle = .full
        dateFormatter.timeStyle = .none
    }

    @objc func editAction() {
        let viewController = AddfreshreleaseViewController()
        navigationController?.present(viewController, animated: true, completion: nil)
    }

    override func viewWillAppear(_ animated: Bool) {
        super.viewWillAppear(animated)

        let appDelegate = UIApplication.shared.delegate as! AppDelegate
        let context = appDelegate.persistentContainer.viewContext

        let fetchRequest = Release_Date.fetchRequest() as NSFetchRequest<Release_Date>

        let sortDescriptor1 = NSSortDescriptor(key: "artist", ascending: true)
        let sortDescriptor2 = NSSortDescriptor(key: "album", ascending: true)
        fetchRequest.sortDescriptors = [sortDescriptor1, sortDescriptor2]
        do {
            freshreleases = try context.fetch(fetchRequest)
        } catch let error {
            print("Could not fetch because of error: \(error).")
        }

        let startOfToday = Calendar.current.startOfDay(for: Date()) as NSDate
        let predicate = NSPredicate(format: "release_date > %@", startOfToday)
        fetchRequest.predicate = predicate

        tableView.reloadData()
    }

    // MARK: - Table view data source

    override func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return freshreleases.count
    }

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

        let cell = tableView.dequeueReusableCell(withIdentifier: "FreshReleaseCellIdentifier", for: indexPath)

        let freshrelease = freshreleases[indexPath.row]

            cell.textLabel?.numberOfLines = 0

        let artist = freshrelease.artist ?? ""
        let album = freshrelease.album ?? ""
        cell.textLabel?.text = artist + "'s\nnew album '" + album + "'\nreleases"

        if let date = freshrelease.release_date as Date? {
            cell.detailTextLabel?.text = dateFormatter.string(from: date)
        } else {
            cell.detailTextLabel?.text = ""
        }

        return cell
    }

    override func tableView(_ tableView: UITableView, canEditRowAt indexPath: IndexPath) -> Bool {
        return true
    }

    // Override to support editing the table view.
    override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
        if freshreleases.count > indexPath.row {
            let freshrelease = freshreleases[indexPath.row]

            // Remove notification
            if let identifier = freshrelease.release_dateId {
                let center = UNUserNotificationCenter.current()
                center.removePendingNotificationRequests(withIdentifiers: [identifier])
            }

            let appDelegate = UIApplication.shared.delegate as! AppDelegate
            let context = appDelegate.persistentContainer.viewContext
            context.delete(freshrelease)
            freshreleases.remove(at: indexPath.row)
            do {
                try context.save()
            } catch let error {
                print("Could not save \(error)")
            }
            tableView.deleteRows(at: [indexPath], with: .fade)
        }
    }

    @available(iOS 11.0, *)

    override func tableView(_ tableView: UITableView,
                   leadingSwipeActionsConfigurationForRowAt indexPath: IndexPath) -> UISwipeActionsConfiguration?

    {
        let modifyAction = UIContextualAction(style: .normal, title:  "Edit", handler: { (ac:UIContextualAction, view:UIView, success:(Bool) -> Void) in
            print("Update action ...")
            let MainStoryboard = UIStoryboard(name: "Main", bundle: Bundle.main)
            let vc : UIViewController = MainStoryboard.instantiateViewController(withIdentifier: "FreshReleaseEdit") as UIViewController
            self.present(vc, animated: true, completion: nil)
            success(true)

        })
        modifyAction.title = "Edit"
        modifyAction.backgroundColor = .blue

        return UISwipeActionsConfiguration(actions: [modifyAction])
    }

    override func tableView(_ tableView: UITableView, canMoveRowAt indexPath: IndexPath) -> Bool {
        return true
    }
}


这是ReleasedTableViewController的代码:

import UIKit
import CoreData
import UserNotifications

class ReleasedTableViewController: UITableViewController{
    var freshreleases = [Release_Date]()
    let dateFormatter = DateFormatter()

    override func viewDidLoad() {
        super.viewDidLoad()

        //create a new button
        let button = UIButton.init(type: .custom)
        //set image for button
        button.setImage(UIImage(named: "Mic App Logo.png"), for: UIControlState.normal)

        dateFormatter.dateStyle = .full
        dateFormatter.timeStyle = .none
    }

    override func viewWillAppear(_ animated: Bool) {
        super.viewWillAppear(animated)

        let appDelegate = UIApplication.shared.delegate as! AppDelegate
        let context = appDelegate.persistentContainer.viewContext

        let fetchRequest = Release_Date.fetchRequest() as NSFetchRequest<Release_Date>

        let sortDescriptor1 = NSSortDescriptor(key: "album", ascending: true)
        let sortDescriptor2 = NSSortDescriptor(key: "artist", ascending: true)
        fetchRequest.sortDescriptors = [sortDescriptor1, sortDescriptor2]
        do {
            freshreleases = try context.fetch(fetchRequest)
        } catch let error {
            print("Could not fetch because of error: \(error).")
        }

        let startOfToday = Calendar.current.startOfDay(for: Date()) as NSDate
        let predicate = NSPredicate(format: "release_date < %@", startOfToday)
        fetchRequest.predicate = predicate

        tableView.reloadData()
    }

    override func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return freshreleases.count
    }

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

        let cell = tableView.dequeueReusableCell(withIdentifier: "FreshReleaseCellIdentifier", for: indexPath)

        let freshrelease = freshreleases[indexPath.row]

        cell.textLabel?.numberOfLines = 0

        let artist = freshrelease.artist ?? ""
        let album = freshrelease.album ?? ""
        cell.textLabel?.text = artist + "'s \nnew album '" + album + "'\nreleases"

        if let date = freshrelease.release_date as Date? {
            cell.detailTextLabel?.text = dateFormatter.string(from: date)
        } else {
            cell.detailTextLabel?.text = ""
        }

        return cell
    }

    override func tableView(_ tableView: UITableView, canEditRowAt indexPath: IndexPath) -> Bool {
        return true
    }

    override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
        if freshreleases.count > indexPath.row {
            let freshrelease = freshreleases[indexPath.row]

            // Remove notification
            if let identifier = freshrelease.release_dateId {
                let center = UNUserNotificationCenter.current()
                center.removePendingNotificationRequests(withIdentifiers: [identifier])
            }

            let appDelegate = UIApplication.shared.delegate as! AppDelegate
            let context = appDelegate.persistentContainer.viewContext
            context.delete(freshrelease)
            freshreleases.remove(at: indexPath.row)
            do {
                try context.save()
            } catch let error {
                print("Could not save \(error)")
            }
            tableView.deleteRows(at: [indexPath], with: .fade)

        }
    }

    @available(iOS 11.0, *)
    override func tableView(_ tableView: UITableView,
                            leadingSwipeActionsConfigurationForRowAt indexPath: IndexPath) -> UISwipeActionsConfiguration?

    {
        let modifyAction = UIContextualAction(style: .normal, title:  "Update", handler: { (ac:UIContextualAction, view:UIView, success:(Bool) -> Void) in
            print("Update action ...")
            success(true)
        })
        modifyAction.title = "Edit"
        modifyAction.backgroundColor = .blue

        return UISwipeActionsConfiguration(actions: [modifyAction])
    }

    override func tableView(_ tableView: UITableView, canMoveRowAt indexPath: IndexPath) -> Bool {
        return true
    }
}

最佳答案

有许多潜在的解决方案。

我建议的最简单的方法是,您的视图控制器侦听UIApplicationDidBecomeActiveNotification。触发此通知后,您可以运行重建获取请求并再次执行。然后,这应该为您提供列表的最新版本。

另一种选择是稍微更改数据模型以在数据模型中包含isReleased标志。现在,在您的应用程序委托中,您可以实现applicationDidBecomeActive。调用此方法时,您可以触发数据库更新以刷新isReleased标志。在视图控制器中,您可以使用NSFetchedResultController并将查询的谓词更改为:

 // Unreleased movies
 fetchRequest.predicate = NSPredicate(format: "isReleased = NO")

 // Released movies
 fetchRequest.predicate = NSPredicate(format: "isReleased = YES")


获取的结果控制器具有委托协议,该协议可让您侦听对基础数据存储的更改,从而使您有机会更新UI。

关于ios - 一旦日期过去,就将数据从一个TableViewController传输到另一个,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/53240343/

10-10 18:35
查看更多