Json简单介绍

1. Json简单介绍

json和plist本质都是一堆以一定格式编写的字符串

json和plist都可以用来表示数据信息

json '{}' 表示字典

json '[]' 表示数组

Json在线格式化查看器:

http://www.jsoneditoronline.org/

http://www.bejson.com/

http://www.sojson.com/

2. Json数据简单解析

解析json和解析plist基本一致

plist中有一句 可以直接把文件的路径 转化成字典或数组

json中是两句 先把文件转成 data 再转成字典或数组

关键类 : NSJSONSerialization

// 获取文件路径

NSURL* path = [[NSBundle mainBundle] URLForResource:@"test.json" withExtension:nil];

//根据文件 转化成 NSData

NSData* data = [NSData dataWithContentsOfURL:path];

// 通过data转 字典

NSArray* dict = [NSJSONSerialization JSONObjectWithData:data options:0 error:nil];

3. 数组泛型介绍

写法:声明数组的时候 在 NSArray 后面 (在*之前) , 写一个 <希望放的类型>

两点好处

1.这个数组 只放<希望放的类型>对象,不放其他的,如果放了会提示(警告)

2.这个数组获取的某一个元素能够直接'点'出来'<希望放的类型>'的属性

@property(strong,nonatomic)NSArray  *spus;

4. 转模型数据中使用setValues中的一对儿方法

在字典中的某个key 有相对应的属性,那么会走 setValue:forKey: 方法

在字典中的某个key 如果在模型中没有相对应的属性,那么会走 setValue:forUndefinedKey: 方法

- (void)setValue:(id)value forKey:(NSString *)key{

   if ([key isEqualToString:@"spus"]) {

       NSArray *temArray = value;

       NSMutableArray *arrM = [NSMutableArray array];

       for (NSDictionary *dict in temArray) {

           GMHomeFoodSpus *homeFoodSpus = [GMHomeFoodSpus foodSpusWithDict:dict];

           [arrM addObject:homeFoodSpus];

       }

       [super setValue:arrM forKey:key];

       return;

//**这里的return一定要写。不然上面的方法全都白写了,会继续执行下面的方法。**

   }

   [super setValue:value forKey:key];

}

- (void)setValue:(id)value forUndefinedKey:(NSString *)key{

   if ([key isEqualToString:@"description"]) {

       self.discountDescription = value;

   }

}

5. 使用SDWebImage加载图片

步骤:

导入SDWebImage

通过 sd_setImageUrl的方法 进行加载

报错http的处理方法,控制器会提示错误, ATS。iOS9.0 之后默认是不支持http了,官方建议使用https。所以需要开启支持http。

需要在infoPlist中配置一个叫做 App Transport Security Settings 的key,这是一个字典,下面再加一个 allow 开的bool类型的 YES即可

图片还是加载不出来,需要把picture属性中的后缀名 删除掉

Alt text

// 使用框架中的方法,将图片的后缀wbp删除掉

NSString *imageName = [self.foodSpusData.picture stringByDeletingPathExtension];

// 使用框架中的方法,设置图片及占位图片

[self.pictureView sd_setImageWithURL:[NSURL URLWithString:imageName] placeholderImage:[UIImage imageNamed:@"img_food_loading"]];

6. tableView里面的小方法

6.1 让屏幕滚动到指定的cell

- (void)scrollToRowAtIndexPath:(NSIndexPath *)indexPath atScrollPosition:(UITableViewScrollPosition)scrollPosition animated:(BOOL)animated;

6.2 获取屏幕上出现的cell信息

view有一个属性,可以获取屏幕上出现的cell信息。返回值是一个数组。

@property (nonatomic, readonly, nullable) NSArray *indexPathsForVisibleRows;

利用这个属性,可以获取到屏幕上出现的第一个cell的indexPath

//获取屏幕上出现的cell的第一个indexpath

NSIndexPath *firstIndexPath = [self.categoryFoodView indexPathsForVisibleRows].firstObject;

6.3 选中指定的indexpath的cell

- (void)selectRowAtIndexPath:(nullable NSIndexPath *)indexPath animated:(BOOL)animated scrollPosition:(UITableViewScrollPosition)scrollPosition;

7. 绘制抛物线动画

步骤:

获取抛物线的起止点

创建关键帧动画

创建bezierPath

将path移动至起点

添加带控制点的抛物线

将path赋值给动画路径

可以给view设置一个额外的的属性,方便能够找到这个view

- (void)startAnimation{

// 获取加号的坐标

CGPoint startPoint = [categoryFoodCell convertPoint:shoppingCartBtn.center toView:self.view];

// 定义动画的结束点坐标

CGPoint endPoint = [self.cartIconView convertPoint:self.cartIconView.center toView:self.view];

// 创建动画小红点

UIImageView *redPointView = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"icon_common_point"]];

[self.view addSubview:redPointView];

redPointView.center = startPoint;

// 设置动画

CAKeyframeAnimation *keyAnimation = [CAKeyframeAnimation animationWithKeyPath:@"position"];

UIBezierPath *path = [UIBezierPath bezierPath];

[path moveToPoint:startPoint];

//绘制抛物线,添加控制点

[path addQuadCurveToPoint:endPoint controlPoint:CGPointMake(startPoint.x - 100, startPoint.y - 100)];

keyAnimation.path = path.CGPath;

keyAnimation.delegate = self;

keyAnimation.removedOnCompletion = NO;

// 设置动画持续时间

keyAnimation.duration = 2;

keyAnimation.fillMode = kCAFillModeForwards;

// 给小红点设置一个额外的标示赋,用于动画播放结束后移除

[keyAnimation setValue:redPointView forKey:@"tagOfRedPointView"];

[redPointView.layer addAnimation:keyAnimation forKey:@"shoppingCart"];

}

//动画播放结束

- (void)animationDidStop:(CAAnimation *)anim finished:(BOOL)flag{

// 将小红点的view先取出来,然后从父控件删除

UIImageView *imageView = [anim valueForKey:@"tagOfRedPointView"];

[imageView removeFromSuperview];

// 加这句话的意思是让imageview立即从内存中释放掉。不然等待ARC释放,还需要一段时间

imageView = nil;

}

8. 自定义控件(集成UIControl)

如果之前是某一个继承view的视图,如果想要监听,可以直接把这个view改成继承自UIControl

通过addtarget的方法 进行监听.

在需要使用的时候,发送一个事件(sendActionsForControlEvents)

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

推荐阅读更多精彩内容

  • 1.自定义控件 a.继承某个控件 b.重写initWithFrame方法可以设置一些它的属性 c.在layouts...
    圍繞的城阅读 3,349评论 2 4
  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥iOS动画全貌。在这里你可以看...
    F麦子阅读 5,094评论 5 13
  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥ios动画全貌。在这里你可以看...
    每天刷两次牙阅读 8,465评论 6 30
  • 1、禁止手机睡眠[UIApplication sharedApplication].idleTimerDisabl...
    DingGa阅读 1,116评论 1 6
  • 很多学生问 为什么要提升学历 学历高究竟有什么用 告诉你学历高低的差距在哪里 1.朋友圈 你的朋友圈是一些什么样子...
    yczsb阅读 421评论 0 0