一般做收藏都是使用数据库或者归档,使用CoreData实现收藏功能就是没事时练一下,实现大概和数据库差不多.

首先创建一个工具类继承NSObject,在里面实现所需要的方法.

  工具类的.h文件:

typedef NS_ENUM(NSUInteger, SelectInEntities) {
    InEntities,
    NotInEntities,
    SelectError,
};

typedef NS_ENUM(NSUInteger, Entities) {
    NewsEntity,
    PostEntity,
    TypeEntity,
    ForumEntity,
};

@interface BFFCoreDataManager : NSObject

// 管理对象上下文(管理者)
@property (readonly, strong, nonatomic) NSManagedObjectContext *managedObjectContext;
// 管理对象模型(表结构)
@property (readonly, strong, nonatomic) NSManagedObjectModel *managedObjectModel;
// 持久化存储协调器(助理)
@property (readonly, strong, nonatomic) NSPersistentStoreCoordinator *persistentStoreCoordinator;
// 保存上下文(保存对数据的修改)
- (void)saveContext;
// 沙盒路径
- (NSURL *)applicationDocumentsDirectory;

//-(SelectInEntities)isInEntities:(Entities)entities
//                    Model:(id)model;

+(BFFCoreDataManager *)shareBFFCoreDataManager;

- (id)isInEntities:(Entities)entities model:(id)model;
+ (BOOL)has:(NSMutableDictionary *)dic arr:(NSArray *)array;
///地方分会
+ (BOOL)hass:(NSMutableDictionary *)dic arr:(NSArray *)array;
///推荐论坛
+ (BOOL)hasss:(BFFDiscussModel *)model arr:(NSArray *)array;
+ (BOOL)haspost:(BFFSelectModel *)model arr:(NSArray *)array;
+ (BOOL)state:(NSArray *)arr url:(NSString *)url;
+ (BOOL)states:(NSArray *)arr ids:(NSString *)ids;

- (id)myModel:(id)model;
@property (nonatomic, strong) BFFCoreDataManager *manager;

@end
    工具类的.m文件

@implementation BFFCoreDataManager
#pragma mark - Core Data stack

@synthesize managedObjectContext = _managedObjectContext;
@synthesize managedObjectModel = _managedObjectModel;
@synthesize persistentStoreCoordinator = _persistentStoreCoordinator;

+ (BFFCoreDataManager *)shareBFFCoreDataManager
{
    /// 单例不能释放
    static BFFCoreDataManager *manager = nil;
    // 保证线程安全, 该方法只走一次
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        manager = [BFFCoreDataManager new];
    });
    return manager;

}

// 获取到沙盒的Document路径

- (NSURL *)applicationDocumentsDirectory {
    // The directory the application uses to store the Core Data store file. This code uses a directory named "com.lanou3g.TheWorldCar" in the application's documents directory.
    return [[[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject];
}

- (NSManagedObjectModel *)managedObjectModel {
    // The managed object model for the application. It is a fatal error for the application not to be able to find and load its model.
    if (_managedObjectModel != nil) {
        return _managedObjectModel;
    }
    NSURL *modelURL = [[NSBundle mainBundle] URLForResource:@"TheWorldCar" withExtension:@"momd"];
    _managedObjectModel = [[NSManagedObjectModel alloc] initWithContentsOfURL:modelURL];
    return _managedObjectModel;
}

- (NSPersistentStoreCoordinator *)persistentStoreCoordinator {
    // The persistent store coordinator for the application. This implementation creates and returns a coordinator, having added the store for the application to it.
    if (_persistentStoreCoordinator != nil) {
        return _persistentStoreCoordinator;
    }
    
    // Create the coordinator and store
    
    _persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:[self managedObjectModel]];
    NSURL *storeURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:@"TheWorldCar.sqlite"];
    NSError *error = nil;
    NSString *failureReason = @"There was an error creating or loading the application's saved data.";
    
    NSDictionary *options = [NSDictionary dictionaryWithObjectsAndKeys:[NSNumber numberWithBool:YES], NSMigratePersistentStoresAutomaticallyOption, [NSNumber numberWithBool:YES], NSInferMappingModelAutomaticallyOption, nil];
    
    if (![_persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeURL options:options error:&error]) {
        // Report any error we got.
        NSMutableDictionary *dict = [NSMutableDictionary dictionary];
        dict[NSLocalizedDescriptionKey] = @"Failed to initialize the application's saved data";
        dict[NSLocalizedFailureReasonErrorKey] = failureReason;
        dict[NSUnderlyingErrorKey] = error;
        error = [NSError errorWithDomain:@"YOUR_ERROR_DOMAIN" code:9999 userInfo:dict];
        // Replace this with code to handle the error appropriately.
        // abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
        NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
        abort();
    }
    
    return _persistentStoreCoordinator;
}

- (NSManagedObjectContext *)managedObjectContext {
    // Returns the managed object context for the application (which is already bound to the persistent store coordinator for the application.)
    if (_managedObjectContext != nil) {
        return _managedObjectContext;
    }
    
    NSPersistentStoreCoordinator *coordinator = [self persistentStoreCoordinator];
    if (!coordinator) {
        return nil;
    }
    _managedObjectContext = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSMainQueueConcurrencyType];
    [_managedObjectContext setPersistentStoreCoordinator:coordinator];
    return _managedObjectContext;
}

#pragma mark - Core Data Saving support

- (void)saveContext {
    NSManagedObjectContext *managedObjectContext = self.managedObjectContext;
    if (managedObjectContext != nil) {
        NSError *error = nil;
        if ([managedObjectContext hasChanges] && ![managedObjectContext save:&error]) {
            // Replace this implementation with code to handle the error appropriately.
            // abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
            NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
            abort();
        }
    }
}

- (id)myModel:(id)model{
    NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
    NSEntityDescription *entity = [NSEntityDescription entityForName:@"Type" inManagedObjectContext:self.managedObjectContext];
    [fetchRequest setEntity:entity];
    NSError *error = nil;
    NSArray *fetchedObjects = [self.managedObjectContext executeFetchRequest:fetchRequest error:&error];
    if (fetchedObjects == nil) {
        NSLog(@"%@", error);
    }
    BFFCollectModel *newsModel = model;
    for (Type *type in fetchedObjects) {
        if ([type.name isEqualToString:newsModel.name]) {
            return type;
        } else {
            return nil;
        }
    }

return nil;
}

// 判断是否在数据库中
- (id)isInEntities:(Entities)entities model:(id)model
{
    switch (entities) {
        case NewsEntity:
        {
            NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
            NSEntityDescription *entity = [NSEntityDescription entityForName:@"News" inManagedObjectContext:self.managedObjectContext];
            [fetchRequest setEntity:entity];
            NSError *error = nil;
            NSArray *fetchedObjects = [self.managedObjectContext executeFetchRequest:fetchRequest error:&error];
            if (fetchedObjects == nil) {
                NSLog(@"%@", error);
            }
            BFFNewsModel *newsModel = model;
            for (News *news in fetchedObjects) {
                if ([news.newsLink isEqualToString:newsModel.newsLink]) {
                    return news;
                }
            }
            return nil;
        }
            break;
        case PostEntity:
        {
            NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
            NSEntityDescription *entity = [NSEntityDescription entityForName:@"Post" inManagedObjectContext:self.managedObjectContext];
            [fetchRequest setEntity:entity];
            NSError *error = nil;
            NSArray *fetchedObjects = [self.managedObjectContext executeFetchRequest:fetchRequest error:&error];
            if (fetchedObjects == nil) {
                NSLog(@"%@", error);
            }
            BFFHotModel *hot = model;
            for (Post *post in fetchedObjects) {
                if ([post.postLink isEqualToString:hot.postLink]) {
                    return post;
                }
            }
            return nil;
        }
            break;
        case TypeEntity:
        {
           
        }
            break;
        case ForumEntity:
        {
            NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
            NSEntityDescription *entity = [NSEntityDescription entityForName:@"Line" inManagedObjectContext:self.managedObjectContext];
            [fetchRequest setEntity:entity];
            NSError *error = nil;
            NSArray *fetchedObjects = [self.managedObjectContext executeFetchRequest:fetchRequest error:&error];
            if (fetchedObjects == nil) {
                NSLog(@"%@", error);
            }
            BFFCarDetailModel *carDetail = model;
            for (Line *line in fetchedObjects) {
                if ([line.seriesId isEqualToString:[NSString stringWithFormat:@"%@", carDetail.seriesId]]) {
                    return line;
                }
            }
            return nil;
        }

break;
        default:
            break;
    }
    return nil;
}
///爱车俱乐部.人车生活
+ (BOOL)has:(NSMutableDictionary *)dic arr:(NSArray *)array{
    NSNumber *num = dic[@"forumId"];
    for (Forum *forum in array) {
        if ([forum.postId isEqualToString:num.description]) {
            return YES;
        }
    }
    return NO;
}
///地方分会
+ (BOOL)hass:(NSMutableDictionary *)dic arr:(NSArray *)array{
    NSNumber *num = dic[@"id"];
    for (Forum *forum in array) {
        if ([forum.postId isEqualToString:num.description]) {
            return YES;
        }
    }
    return NO;
}
///论坛推荐
+ (BOOL)hasss:(BFFDiscussModel *)model arr:(NSArray *)array{
    for (Forum *forum in array) {
        if ([forum.postId isEqualToString:model.forumId.description]) {
            return YES;
        }
    }
     return NO;
}
///帖子收藏
+ (BOOL)haspost:(BFFSelectModel *)model arr:(NSArray *)array{
    for (Post *post in array) {
        if ([post.postLink isEqualToString:model.postLink]) {
            return YES;
        }
    }
    return NO;
}
///改变帖子收藏按钮图标
+ (BOOL)state:(NSArray *)arr url:(NSString *)url{
    for (Post *post in arr) {
        if ([post.postLink isEqualToString:url]) {
            return YES;
        }
    }
    return NO;
}
///改变论坛收藏按钮图标
+ (BOOL)states:(NSArray *)arr ids:(NSString *)ids{
    for (Forum *forum in arr) {
        if ([forum.postId.description isEqualToString:ids]) {
            return YES;
        }
    }
    return NO;
}

//-(SelectInEntities)isInEntities:(Entities)entities
//                          Model:(id)model
//{
//    switch (entities) {
//        case NewsEntity:
//        {
//            NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
//            NSEntityDescription *entity = [NSEntityDescription entityForName:@"News" inManagedObjectContext:self.managedObjectContext];
//            [fetchRequest setEntity:entity];
//            NSError *error = nil;
//            NSArray *fetchedObjects = [self.managedObjectContext executeFetchRequest:fetchRequest error:&error];
//            if (fetchedObjects == nil) {
//                NSLog(@"%@", error);
//            }
//            BFFNewsModel *newsModel = model;
//
//            for (News *news in fetchedObjects) {
//
//                if ([news.newsLink isEqualToString:newsModel.newsLink]) {
//                    return InEntities;
//                } else {
//                    return NotInEntities;
//                }
//
//            }
//
//        }
//            break;
//            case PostEntity:
//        {
//
//        }
//            break;
//            case LineEntity:
//        {
//
//        }
//            break;
//            case ForumEntity:
//        {
//
//        }
//            break;
//        default:
//            break;
//    }
//    return SelectError;
//}
@end
  接下来在收藏页面创建一个Button实现收藏

- (void)collectionBut:(id)sender{

BFFCollectModel *model = self.tempModel;
    if ([self.manager myModel:model] == nil) {
       Type *type = [NSEntityDescription insertNewObjectForEntityForName:@"Type" inManagedObjectContext:self.manager.managedObjectContext];
        type.name = model.name;
        type.priceRange = model.priceRange;
        type.photo = model.photo;
        type.uid = [NSString stringWithFormat:@"%@", model.uid];
        [self.manager saveContext];
        
        self.collectLabel.text = @"已经收藏";
        self.collectLabel.hidden = NO;
        dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
            self.collectLabel.hidden = YES;
        });
        
        
    } else {
        [self.manager.managedObjectContext deleteObject:[self.manager myModel:model]];
        [self.manager saveContext];
        self.collectLabel.text = @"已取消收藏";
        self.collectLabel.hidden = NO;
        dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
            self.collectLabel.hidden = YES;
        });
    }
}
在我的收藏页面把数据取出

- (void)createLineData
{
    self.typeArr = [NSMutableArray array];
    NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
    NSEntityDescription *entity = [NSEntityDescription entityForName:@"Type" inManagedObjectContext:self.manager.managedObjectContext];
    [fetchRequest setEntity:entity];
    NSError *error = nil;
    NSArray *fetchedObjects = [self.manager.managedObjectContext executeFetchRequest:fetchRequest error:&error];
    
    if (fetchedObjects == nil) {
        NSLog(@"%@", error);
    }
    [self.typeArr addObjectsFromArray:fetchedObjects];
    [self.tableView reloadData];
    
}
这些数据都铺在了tableView上接下来实现删除的操作

- (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath
{
    if (editingStyle == UITableViewCellEditingStyleDelete) {
        if (self.titleSegment.selectedSegmentIndex == 0) {
            News *news = self.newsArr[indexPath.row];
            [self.manager.managedObjectContext deleteObject:news];
            [self.manager saveContext];
            [self.newsArr removeObjectAtIndex:indexPath.row];
            [self.tableView deleteRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationLeft];
        }else if (self.titleSegment.selectedSegmentIndex == 1){
            Post *post = self.postArr[indexPath.row];
            [self.manager.managedObjectContext deleteObject:post];
            [self.manager saveContext];
            [self.postArr removeObjectAtIndex:indexPath.row];
             [self.tableView deleteRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationLeft];
        }else if (self.titleSegment.selectedSegmentIndex == 2){
            Forum *forum = self.forumArr[indexPath.row];
            [self.manager.managedObjectContext deleteObject:forum];
            [self.manager saveContext];
            [self.forumArr removeObjectAtIndex:indexPath.row];
            [self.tableView deleteRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationLeft];

}else{
        
            Type *type = self.typeArr[indexPath.row];
            [self.manager.managedObjectContext deleteObject:type];
             [self.manager saveContext];
            [self.typeArr removeObjectAtIndex:indexPath.row];
            [self.tableView deleteRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationLeft];
        
        }
    }
    [self.tableView reloadData];
}
      这些就是实现收藏的过程

iOS使用CoreData实现收藏功能的更多相关文章

  1. 改进iOS客户端的升级提醒功能

    改进iOS客户端的升级提醒功能 功能设计 先申明一下,我是码农,不是一个产品经理,但我觉得现有市面上的很多 App,设计的 "升级提示功能" 都不太友好.在此分享一下我的想法,欢迎 ...

  2. Yii中Ajax的使用,如收藏功能

    view中 <?php $cs=Yii::app()->clientScript; $cs->registerScriptFile('http://ajax.googleapis.c ...

  3. iOS 用UISearchDisplayController实现查找功能

    UISearchDisplayController是iOS中用于处理搜索功能的控制器,此控制器需要和UISearchBar结合使用 示例代码如下: // // WKRootViewController ...

  4. iOS Swift WisdomScanKit图片浏览器功能SDK

    iOS Swift WisdomScanKit图片浏览器功能SDK使用 一:简介      WisdomScanKit 由 Swift4.2版编写,完全兼容OC项目调用. WisdomScanKit的 ...

  5. iOS蓝牙BLE4.0通信功能

    概述 iOS蓝牙BLE4.0通信功能,最近刚学的苹果,为了实现蓝牙门锁的项目,找了一天学习了下蓝牙的原理,亲手测试了一次蓝牙的通信功能,结果成功了,那么就把我学习的东西分享一下. 详细 代码下载:ht ...

  6. 【Android】3.21 示例21—兴趣点收藏功能

    分类:C#.Android.VS2015.百度地图应用: 创建日期:2016-02-04 简介:介绍如何创建.管理本地收藏的兴趣点数据 详述: (1)新建本地点收藏: (2)查看已收藏本地点: (3) ...

  7. mxonline实战9,我要学习功能块,机构详情展示,收藏功能

    对应github地址:第9天   一. 实现我要学习功能

  8. 18、Django实战第18天:课程机构收藏功能

    这里点击"收藏"也是ajax异步操作,我在operation.model.py中创建了一个用户收藏表,其中fav_id字段,如果我们收藏的是课程,那就是课程id,如果收藏的是课程机 ...

  9. ios开发视频播放后台下载功能实现 :1,ios播放视频 ,包含基于AVPlayer播放器,2,实现下载,iOS后台下载(多任务同时下载,单任务下载,下载进度,下载百分比,文件大小,下载状态)(真机调试功能正常)

    ABBPlayerKit ios开发视频播放后台下载功能实现 : 代码下载地址:https://github.com/niexiaobo/ABBPlayerKit github资料学习和下载地址:ht ...

随机推荐

  1. ActiveMQ(3) ActiveMQ创建(simpleAuthenticationPlugin)安全认证

    控制端安全认证: ActiveMQ目录conf下jetty.xml: <bean id="securityLoginService" class="org.ecli ...

  2. 网络流专题练习Day1

    04/16 一共做了8道题 首先网络流目前自己掌握的只有最大流Dinic算法和普通的费用流算法 有空还要去学习一下SAP和ZKW费用流(flag早早立在前面以后看到都有动力... 但网络流的算法个人认 ...

  3. 【mysql优化】大数据量分页优化

    limit 翻页原理 limit offset,N, 当offset非常大时, 效率极低, 原因是mysql并不是跳过offset行,然后单取N行, 而是取offset+N行,返回放弃前offset行 ...

  4. 编写类du命令Python脚本

    #!/usr/bin/env python #_*_ coding:utf-8 _*_ #计算整个目录的大小,脚本接受-H参数,来加上适当的单位 #功能像du看齐 import os,sys from ...

  5. python 使用装饰器并记录log

    1.首先定义一个log文件 # -*- coding: utf-8 -*- import os import time import logging import sys log_dir1=os.pa ...

  6. Xcode升级到7之后 发现速度超级慢

    Xcode升级到7之后 发现速度超级慢 转自:http://www.jianshu.com/p/608803eb1e12 解决方法,慢google了一下是由于插件造成饿,于是乎将Alcatraz安装的 ...

  7. 动态加载ajax 腾讯视频评论

    import urllib import urllib2 import os import requests import re import json sns_url = 'http://sns.v ...

  8. KVM(一)简介及安装

    1. KVM 介绍 1.0 虚拟化简史 其中,KVM 全称是 基于内核的虚拟机(Kernel-based Virtual Machine),它是一个 Linux 的一个内核模块,该内核模块使得 Lin ...

  9. AC日记——T-Shirt Hunt codeforces 807b

    T-Shirt Hunt 思路: 水题: 代码: #include <cstdio> #include <cstring> #include <iostream> ...

  10. JS / jquery 实现页面 面板拖动 QQ网页版登陆页面拖动

    参考:慕课网DOM实践探秘 http://www.imooc.com/learn/138 实现需求:点击页面头部,可以拖动面板.使用js原生和jquery 各实现一次. 可以学到:1.鼠标在当前页面的 ...