一般做收藏都是使用数据库或者归档,使用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. 修改select样式,vue select

    <style> .selectbox{ width: 200px; display: inline-block; overflow-x: hidden; height: 28px; lin ...

  2. css和javascript中图片路径的不同

    之前在写前端代码时,在图片路径的设置那里经常会遇到一个问题.比方说,我 (1)在根目录下面新建了个"images"文夹,里面放了张图片top.gif (2)在根目录下另外新建了两个 ...

  3. 调整文本输入框placeholder的颜色等样式

    input::-webkit-input-placeholder{     color: white !important;}input:-moz-placeholder{    color: whi ...

  4. 线段树+矩阵快速幂 Codeforces Round #373 (Div. 2) E

    http://codeforces.com/contest/719/problem/E 题目大意:给你一串数组a,a[i]表示第i个斐波那契数列,有如下操作 ①对[l,r]区间+一个val ②求出[l ...

  5. leetcode-501. Find Mode in Binary Search Tree

    Given a binary search tree (BST) with duplicates, find all the mode(s) (the most frequently occurred ...

  6. bzoj 1297 矩阵乘法变形

    首先对于矩阵乘法的功能有很多,记得有篇论文叫矩阵乘法在信息学竞赛中的应用,里面详细介绍了矩阵的 作用 其中一个就是求图的固定时间方案数,也就是给定一张图,每两个点之间由一条边长为1的边相连, 求任意两 ...

  7. wiki 2490 导弹拦截塔

    2013-09-23 21:16 二分答案+匈牙利判断 对于每一个时间,我们重新建一张二分图,由于每个塔可能打多次,所以要拆点, 对于每个拆的点的可行飞行距离为(mid-t1)-(ll-1)*(t1+ ...

  8. 填坑webpack

    1.Concepts: webpack is a module bundler for modern JS applications. Since there are lots of complex ...

  9. Linux内核态抢占机制分析【转】

    转自:http://blog.csdn.net/yiyeguzhou100/article/details/53097665 目录(?)[-] 1非抢占式和可抢占式内核的区别 21 用户态抢占User ...

  10. golang写一个简单的爬虫

    package main import( "fmt" "io/ioutil" "net/http" ) func gethtml(url s ...