swift3.0 coreData的使用-日记本demo

写在前面
弄了下个人站...防止内容再次被锁定...所有东西都在这里面
welcome~
个人博客

效果

效果.gif

需求分析

基于官方MasterDetail模板,官方写了很多复杂的coredata逻辑,在此基础上快速开发简单的日记本程序。

- 主要功能:增、删、改、查
- 界面用默认的界面,将detail页面改为`UITextView`可编辑
- 主页面进行 增、删、查操作
- 子页面进行 删、改、查操作

需求很简单,官方模板还添加了按时间排序的操作

创建工程

选择 M-D模式


M-D.png

使用swift和coredata

选择语言和coredata.png

添加数据库

官方给数据库添加了一个时间戳字段,我们再添加一个内容字段就可以了


添加字段.png

改写Detail页面

改成textview,读取数据库中的noteDetail内容字段
需要增加保存和删除操作
由于设置了detailItem:Event这个全局变量是由上一级传递过来的,我们就可以对这行内容直接进行操作

    //当前entity
    var detailItem: Event? {
        didSet {
            // Update the view.
            self.configureView()
        }
    }
//删除
    @IBAction func deleteNote(_ sender: Any) {
        print("deleted")
        let context = self.detailItem?.managedObjectContext
        context?.delete(self.detailItem!)
          //保存到数据库
        self.saveData(context: context!)
        _ = self.navigationController?.popViewController(animated: true)

    }
//保存数据
    func saveObject() {
        print("saved")
        let newEvent = self.detailItem
        let context = self.detailItem?.managedObjectContext
        newEvent?.noteDetail = self.detailTextView.text
        newEvent?.timestamp = NSDate()
        //保存到数据库
        self.saveData(context: context!)
        //返回
        _ = self.navigationController?.popViewController(animated: true)
    }
    //保存数据
    func saveData(context:NSManagedObjectContext) {
        do {
            try context.save()
        } catch {
            let nserror = error as NSError
            fatalError("Unresolved error \(nserror), \(nserror.userInfo)")
        }
    }

在navBarRight上增加一个按钮用于保存

    override func viewDidLoad() {
        super.viewDidLoad()
        //增加保存按钮
        let saveBtn = UIBarButtonItem(barButtonSystemItem: .save, target: self, action: #selector(saveObject))
        self.navigationItem.rightBarButtonItem = saveBtn
        self.title = "写点什么吧..."   
        self.configureView()
    }
    //配置界面 显示日志内容
    func configureView() {
        if let detail = self.detailItem {
            if let textView = self.detailTextView {
                textView.text = detail.noteDetail!.description
            }
        }
    }

改写Master页面

- 更改cell展示内容
- 点击cell的页面
- 更改新增日志按钮的方法
- 新增刷新tableview
  • 更改cell展示内容
    cell没有太多要更改的 只是显示样式更改下就行
    //配置cell内容
    func configureCell(_ cell: UITableViewCell, withEvent event: Event) {
        cell.textLabel!.text = event.noteDetail?.description
        cell.detailTextLabel!.text = event.timestamp!.description
    }
  • 点击cell的页面
    由于默认的M-D页面模式 点击cell是直接指向D页面,我们把他删掉,写到tableview的didSelectRowAt方法中,使用navigationController并传递当前查询出来的数据对象
    我这里是使用stroyboard ID来获取视窗
    override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        //点击cell push
        let object = self.fetchedResultsController.object(at: indexPath)
        let story = UIStoryboard(name: "Main", bundle: Bundle.main)
        let controller = story.instantiateViewController(withIdentifier: "detail") as! DetailViewController
        controller.detailItem = object
        self.navigationController?.pushViewController(controller, animated: true)
    }
  • 更改新增日志按钮的方法
    默认模式是点击新增直接tableview多一行数据,我们这里的需求则是进入新增的编辑页面。
    我们给新增按钮的方法更改一下,push到新页面就可以了
    //插入新记事本
    func insertNewObject(_ sender: Any) {
        //初始化 插入时间戳 和 空数据
        let context = self.fetchedResultsController.managedObjectContext
        let newEvent = Event(context: context)
        newEvent.timestamp = NSDate()
        newEvent.noteDetail = ""
        //保存
        do {
            try context.save()
        } catch {
            let nserror = error as NSError
            fatalError("Unresolved error \(nserror), \(nserror.userInfo)")
        }
   
        //push
        let story = UIStoryboard(name: "Main", bundle: Bundle.main)
        let controller = story.instantiateViewController(withIdentifier: "detail") as! DetailViewController
        controller.detailItem = newEvent
        self.navigationController?.pushViewController(controller, animated: true)
    }
  • 新增刷新tableview
    由于返回机制是由navigationController来控制的,我们需要在D页面返回时刷新一下tableview,重读数据库,让新数据能展现出来
override func viewWillAppear(_ animated: Bool) {
        super.viewWillAppear(animated)
        //返回时刷新数据
        self.tableView.reloadData()
    }

Demo地址

https://github.com/gongxiaokai/SimpleNote

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,980评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,178评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,868评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,498评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,492评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,521评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,910评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,569评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,793评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,559评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,639评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,342评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,931评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,904评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,144评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,833评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,350评论 2 342

推荐阅读更多精彩内容