Json簡(jiǎn)單介紹

1. Json簡(jiǎn)單介紹

json和plist本質(zhì)都是一堆以一定格式編寫的字符串

json和plist都可以用來(lái)表示數(shù)據(jù)信息

json '{}' 表示字典

json '[]' 表示數(shù)組

Json在線格式化查看器:

http://www.jsoneditoronline.org/

http://www.bejson.com/

http://www.sojson.com/

2. Json數(shù)據(jù)簡(jiǎn)單解析

解析json和解析plist基本一致

plist中有一句 可以直接把文件的路徑 轉(zhuǎn)化成字典或數(shù)組

json中是兩句 先把文件轉(zhuǎn)成 data 再轉(zhuǎn)成字典或數(shù)組

關(guān)鍵類 : NSJSONSerialization

// 獲取文件路徑

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

//根據(jù)文件 轉(zhuǎn)化成 NSData

NSData* data = [NSData dataWithContentsOfURL:path];

// 通過(guò)data轉(zhuǎn) 字典

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

3. 數(shù)組泛型介紹

寫法:聲明數(shù)組的時(shí)候 在 NSArray 后面 (在*之前) , 寫一個(gè) <希望放的類型>

兩點(diǎn)好處

1.這個(gè)數(shù)組 只放<希望放的類型>對(duì)象,不放其他的,如果放了會(huì)提示(警告)

2.這個(gè)數(shù)組獲取的某一個(gè)元素能夠直接'點(diǎn)'出來(lái)'<希望放的類型>'的屬性

@property(strong,nonatomic)NSArray ?*spus;

4. 轉(zhuǎn)模型數(shù)據(jù)中使用setValues中的一對(duì)兒方法

在字典中的某個(gè)key 有相對(duì)應(yīng)的屬性,那么會(huì)走 setValue:forKey: 方法

在字典中的某個(gè)key 如果在模型中沒(méi)有相對(duì)應(yīng)的屬性,那么會(huì)走 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一定要寫灶伊。不然上面的方法全都白寫了剪芍,會(huì)繼續(xù)執(zhí)行下面的方法。**

? ?}

? ?[super setValue:value forKey:key];

}

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

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

? ? ? ?self.discountDescription = value;

? ?}

}

5. 使用SDWebImage加載圖片

步驟:

導(dǎo)入SDWebImage

通過(guò) sd_setImageUrl的方法 進(jìn)行加載

報(bào)錯(cuò)http的處理方法抡爹,控制器會(huì)提示錯(cuò)誤, ATS嘴纺。iOS9.0 之后默認(rèn)是不支持http了,官方建議使用https。所以需要開啟支持http。

需要在infoPlist中配置一個(gè)叫做 App Transport Security Settings 的key,這是一個(gè)字典,下面再加一個(gè) allow 開的bool類型的 YES即可

圖片還是加載不出來(lái),需要把picture屬性中的后綴名 刪除掉

Alt text

// 使用框架中的方法锨能,將圖片的后綴wbp刪除掉

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

// 使用框架中的方法,設(shè)置圖片及占位圖片

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

6. tableView里面的小方法

6.1 讓屏幕滾動(dòng)到指定的cell

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

6.2 獲取屏幕上出現(xiàn)的cell信息

view有一個(gè)屬性芍耘,可以獲取屏幕上出現(xiàn)的cell信息。返回值是一個(gè)數(shù)組熄阻。

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

利用這個(gè)屬性斋竞,可以獲取到屏幕上出現(xiàn)的第一個(gè)cell的indexPath

//獲取屏幕上出現(xiàn)的cell的第一個(gè)indexpath

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

6.3 選中指定的indexpath的cell

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

7. 繪制拋物線動(dòng)畫

步驟:

獲取拋物線的起止點(diǎn)

創(chuàng)建關(guān)鍵幀動(dòng)畫

創(chuàng)建bezierPath

將path移動(dòng)至起點(diǎn)

添加帶控制點(diǎn)的拋物線

將path賦值給動(dòng)畫路徑

可以給view設(shè)置一個(gè)額外的的屬性,方便能夠找到這個(gè)view

- (void)startAnimation{

// 獲取加號(hào)的坐標(biāo)

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

// 定義動(dòng)畫的結(jié)束點(diǎn)坐標(biāo)

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

// 創(chuàng)建動(dòng)畫小紅點(diǎn)

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

[self.view addSubview:redPointView];

redPointView.center = startPoint;

// 設(shè)置動(dòng)畫

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

UIBezierPath *path = [UIBezierPath bezierPath];

[path moveToPoint:startPoint];

//繪制拋物線秃殉,添加控制點(diǎn)

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

keyAnimation.path = path.CGPath;

keyAnimation.delegate = self;

keyAnimation.removedOnCompletion = NO;

// 設(shè)置動(dòng)畫持續(xù)時(shí)間

keyAnimation.duration = 2;

keyAnimation.fillMode = kCAFillModeForwards;

// 給小紅點(diǎn)設(shè)置一個(gè)額外的標(biāo)示賦坝初,用于動(dòng)畫播放結(jié)束后移除

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

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

}

//動(dòng)畫播放結(jié)束

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

// 將小紅點(diǎn)的view先取出來(lái),然后從父控件刪除

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

[imageView removeFromSuperview];

// 加這句話的意思是讓imageview立即從內(nèi)存中釋放掉钾军。不然等待ARC釋放鳄袍,還需要一段時(shí)間

imageView = nil;

}

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

如果之前是某一個(gè)繼承view的視圖,如果想要監(jiān)聽,可以直接把這個(gè)view改成繼承自UIControl

通過(guò)addtarget的方法 進(jìn)行監(jiān)聽.

在需要使用的時(shí)候,發(fā)送一個(gè)事件(sendActionsForControlEvents)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市吏恭,隨后出現(xiàn)的幾起案子拗小,更是在濱河造成了極大的恐慌,老刑警劉巖樱哼,帶你破解...
    沈念sama閱讀 216,919評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件哀九,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡搅幅,警方通過(guò)查閱死者的電腦和手機(jī)阅束,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)茄唐,“玉大人息裸,你說(shuō)我怎么就攤上這事』Ρ啵” “怎么了呼盆?”我有些...
    開封第一講書人閱讀 163,316評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)漾抬。 經(jīng)常有香客問(wèn)我宿亡,道長(zhǎng),這世上最難降的妖魔是什么纳令? 我笑而不...
    開封第一講書人閱讀 58,294評(píng)論 1 292
  • 正文 為了忘掉前任挽荠,我火速辦了婚禮克胳,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘圈匆。我一直安慰自己漠另,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,318評(píng)論 6 390
  • 文/花漫 我一把揭開白布跃赚。 她就那樣靜靜地躺著笆搓,像睡著了一般。 火紅的嫁衣襯著肌膚如雪纬傲。 梳的紋絲不亂的頭發(fā)上满败,一...
    開封第一講書人閱讀 51,245評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音叹括,去河邊找鬼算墨。 笑死,一個(gè)胖子當(dāng)著我的面吹牛汁雷,可吹牛的內(nèi)容都是我干的净嘀。 我是一名探鬼主播,決...
    沈念sama閱讀 40,120評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼侠讯,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼挖藏!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起厢漩,我...
    開封第一講書人閱讀 38,964評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤膜眠,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后溜嗜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體柴底,經(jīng)...
    沈念sama閱讀 45,376評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,592評(píng)論 2 333
  • 正文 我和宋清朗相戀三年粱胜,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了柄驻。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,764評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡焙压,死狀恐怖鸿脓,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情涯曲,我是刑警寧澤野哭,帶...
    沈念sama閱讀 35,460評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站幻件,受9級(jí)特大地震影響拨黔,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜绰沥,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,070評(píng)論 3 327
  • 文/蒙蒙 一篱蝇、第九天 我趴在偏房一處隱蔽的房頂上張望贺待。 院中可真熱鬧,春花似錦零截、人聲如沸麸塞。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,697評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)哪工。三九已至,卻和暖如春弧哎,著一層夾襖步出監(jiān)牢的瞬間雁比,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,846評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工撤嫩, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留章贞,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,819評(píng)論 2 370
  • 正文 我出身青樓非洲,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親蜕径。 傳聞我的和親對(duì)象是個(gè)殘疾皇子两踏,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,665評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 1.自定義控件 a.繼承某個(gè)控件 b.重寫initWithFrame方法可以設(shè)置一些它的屬性 c.在layouts...
    圍繞的城閱讀 3,387評(píng)論 2 4
  • 在iOS中隨處都可以看到絢麗的動(dòng)畫效果,實(shí)現(xiàn)這些動(dòng)畫的過(guò)程并不復(fù)雜兜喻,今天將帶大家一窺iOS動(dòng)畫全貌梦染。在這里你可以看...
    F麥子閱讀 5,110評(píng)論 5 13
  • 在iOS中隨處都可以看到絢麗的動(dòng)畫效果,實(shí)現(xiàn)這些動(dòng)畫的過(guò)程并不復(fù)雜朴皆,今天將帶大家一窺ios動(dòng)畫全貌帕识。在這里你可以看...
    每天刷兩次牙閱讀 8,485評(píng)論 6 30
  • 1、禁止手機(jī)睡眠[UIApplication sharedApplication].idleTimerDisabl...
    DingGa閱讀 1,117評(píng)論 1 6
  • 很多學(xué)生問(wèn) 為什么要提升學(xué)歷 學(xué)歷高究竟有什么用 告訴你學(xué)歷高低的差距在哪里 1.朋友圈 你的朋友圈是一些什么樣子...
    yczsb閱讀 426評(píng)論 0 0