AFNetworking
報錯并輸出:“
Error Domain=NSCocoaErrorDomain Code=3840 "The operation couldn’t be completed. (Cocoa error 3840.)" (JSON text did not start with array or object and option to allow fragments not set.) UserInfo=0x8ea19a0 {NSDebugDescription=JSON text did not start with array or object and option to allow fragments not set.}
”原因
AFNetworking默認把響應(yīng)結(jié)果當成json來處理(默認:manager.responseSerializer = [AFJSONResponseSerializer serializer]
) 。
如果返回的數(shù)據(jù) 并不是一個json文本,而是一個html網(wǎng)頁。但是AFNetworking并不知道!然后依舊以json的形式去解析,顯然沒辦法把一個網(wǎng)頁解析成一個字典或者數(shù)組,所以產(chǎn)生錯誤。解決
要讓它能夠正確地處理這個情況,而非提示一個錯誤。
則須告訴AFNetworking別把這個網(wǎng)頁當json來處理!需要在發(fā)送請求前加入:manager.responseSerializer = [AFHTTPResponseSerializer serializer]
請求超時的時間限制 設(shè)置無效:
-(void)GETUrl:(NSString *)url parameters:(NSDictionary *)parameters success:(void (^)(id))success failure:(void (^)(NSError *))failure { AFHTTPSessionManager *manager = [AFHTTPSessionManager manager]; manager.securityPolicy = [AFSecurityPolicy policyWithPinningMode:AFSSLPinningModeNone]; //表示不做SSL pinning manager.requestSerializer.timeoutInterval = 6; //請求超時(????????) //manager.requestSerializer = [AFHTTPRequestSerializer serializer]; manager.requestSerializer = [AFJSONRequestSerializer serializer]; manager.responseSerializer = [AFJSONResponseSerializer serializer]; manager.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"application/json", @"text/html",@"text/json",@"text/javascript",@"text/html",@"text/plain", nil]; [manager GET:url parameters:parameters progress:nil success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) { if (success) { success(responseObject); } } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) { failure(error); }]; }
超時時間設(shè)置的位置 應(yīng)該放在“
manager.requestSerializer
”設(shè)置好之后:-(void)GETUrl:(NSString *)url parameters:(NSDictionary *)parameters success:(void (^)(id))success failure:(void (^)(NSError *))failure { AFHTTPSessionManager *manager = [AFHTTPSessionManager manager]; manager.securityPolicy = [AFSecurityPolicy policyWithPinningMode:AFSSLPinningModeNone]; //表示不做SSL pinning //manager.requestSerializer = [AFHTTPRequestSerializer serializer]; manager.requestSerializer = [AFJSONRequestSerializer serializer]; manager.responseSerializer = [AFJSONResponseSerializer serializer]; manager.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"application/json", @"text/html",@"text/json",@"text/javascript",@"text/html",@"text/plain", nil]; manager.requestSerializer.timeoutInterval = 6; //請求超時 (????????????????) [manager GET:url parameters:parameters progress:nil success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) { if (success) { success(responseObject); } } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) { failure(error); }]; }
或者:
使用KVO:直接在觀察屬性的變化的過程中,對屬性進行修改!
// 設(shè)置超時時間(設(shè)置有效) [manager.requestSerializer willChangeValueForKey:@"timeoutInterval"]; manager.requestSerializer.timeoutInterval = 30; [manager.requestSerializer didChangeValueForKey:@"timeoutInterval”];
手動實現(xiàn)鍵值觀察
在property的值改變之前調(diào)用“willChangeValueForKey:
”,在值改變之后調(diào)用“didChangeValueForKey:
”。
FMDB
“No such table xxx” 類型的錯誤。
原因:
一、關(guān)鍵字 與 插入數(shù)據(jù)時的關(guān)鍵字 不匹配;
二、數(shù)據(jù)模型引用 錯誤。對策:
一、建立數(shù)據(jù)表時,認真檢查;
二、clean一下工程 或 重啟Xcode。
“table xxx has no column named xxxxx” 類型的錯誤
原因:
一、表里確實沒有 這個字段。
要在建表的語句中加上 這個字段,另外還要 在所有出現(xiàn)了這個表的語句的地方,都要添加上這個字段。 (表:建立 + 出現(xiàn))
二、表里之前 沒有這個字段,但現(xiàn)在 添加上了。然而,數(shù)據(jù)庫里面已經(jīng) 存儲了 沒添加這個字段之前的記錄??!如果是這樣的話,Xcode會報錯崩潰,對策:修改 數(shù)據(jù)庫的版本號 或者 修改 數(shù)據(jù)庫的名稱。
IQKeyboardManager
當界面有tableView時,且含有輸入框時:
點擊輸入框,整個界面會集體上移??!效果展示:
點擊輸入時,界面會整體上移?。?strong>導航欄、tableView整體上滑)
解決:
自己對(系統(tǒng)默認的)輸入框進行設(shè)置 或 自定義一個輸入框?。?!
使用默認的輸入框,進行處理:
- 1.監(jiān)聽鍵盤在編輯狀態(tài)的高度,調(diào)整界面的約束:上移輸入框??!
- 2.輸入框 結(jié)束編輯狀態(tài),調(diào)整界面的約束:下移輸入框??!
禁用IQKeyboardManager
-(void)viewWillAppear:(BOOL)animated { [super viewWillAppear:animated]; [[IQKeyboardManager sharedManager] setEnable:NO]; [IQKeyboardManager sharedManager].enableAutoToolbar = NO;//顯示它自帶鍵盤工具條 開關(guān) } -(void)viewWillDisappear:(BOOL)animated { [super viewWillDisappear:animated]; [[IQKeyboardManager sharedManager] setEnable:YES]; }
視圖創(chuàng)建: (在“
- (void)viewDidLoad { }
”里)self.edgesForExtendedLayout = UIRectEdgeNone; self.discussTabV = [[UITableView alloc] initWithFrame:CGRectMake(0, 0, 0, 0) style:UITableViewStylePlain]; self.discussTabV.dataSource = self; self.discussTabV.delegate = self; self.discussTabV.backgroundColor = All_BG_Color; self.discussTabV.bounces = NO; [self.view addSubview:self.discussTabV]; __weak typeof(self) weakSelf = self; [self.discussTabV mas_makeConstraints:^(MASConstraintMaker *make) { make.left.equalTo(weakSelf.view); make.right.equalTo(weakSelf.view); make.top.equalTo(weakSelf.view); make.bottom.equalTo(weakSelf.view).with.offset(-SCREEN_WIDTH*100.f/750.f); }]; /** 輸入框視圖 */ _whiteV = [[UIView alloc] init]; //白色背景視圖 _whiteV.backgroundColor = [UIColor whiteColor]; [self.view addSubview:_whiteV]; [_whiteV mas_makeConstraints:^(MASConstraintMaker *make) { make.left.equalTo(weakSelf.view); make.right.equalTo(weakSelf.view); make.height.mas_equalTo(SCREEN_WIDTH*100.f/750.f); make.bottom.equalTo(weakSelf.view); }]; _commentTF = [[UITextField alloc] init]; //評論輸入框 [_whiteV addSubview:_commentTF]; [_commentTF mas_makeConstraints:^(MASConstraintMaker *make) { make.left.equalTo(_whiteV).with.offset(SCREEN_WIDTH*30.f/750.f); make.right.equalTo(_whiteV).with.offset(-SCREEN_WIDTH*30.f/750.f); make.top.equalTo(_whiteV).with.offset(SCREEN_WIDTH*20.f/750.f); make.bottom.equalTo(_whiteV).with.offset(-SCREEN_WIDTH*20.f/750.f); }]; _commentTF.backgroundColor = [UIColor whiteColor]; _commentTF.placeholder = @"我的回答"; _commentTF.clearButtonMode = UITextFieldViewModeWhileEditing; _commentTF.borderStyle = UITextBorderStyleRoundedRect; _commentTF.returnKeyType = UIReturnKeySend; //回車按鈕設(shè)置為“發(fā)送” _commentTF.delegate = self; /** ??????監(jiān)聽鍵盤的通知?????? */ [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillChangeFrameNotify:) name:UIKeyboardWillChangeFrameNotification object:nil];
監(jiān)聽鍵盤的變化:
/** ??????當鍵盤改變了frame(位置、尺寸)時,調(diào)用?????? */ -(void)keyboardWillChangeFrameNotify:(NSNotification*)notify { CGRect keyboardFrame = [notify.userInfo[UIKeyboardFrameEndUserInfoKey] CGRectValue]; __weak typeof(self) weakSelf = self; [self.discussTabV mas_updateConstraints:^(MASConstraintMaker *make) { make.left.equalTo(weakSelf.view); make.right.equalTo(weakSelf.view); make.top.equalTo(weakSelf.view); make.bottom.equalTo(weakSelf.view).with.offset(-keyboardFrame.size.height-SCREEN_WIDTH*100.f/750.f); }]; [_whiteV mas_updateConstraints:^(MASConstraintMaker *make) { //只負責新增約束 make.left.equalTo(weakSelf.view); make.right.equalTo(weakSelf.view); make.height.mas_equalTo(SCREEN_WIDTH*100.f/750.f); make.bottom.equalTo(weakSelf.view).with.offset(-keyboardFrame.size.height); }]; }
輸入框結(jié)束編輯:
#pragma mark - UITextFieldDelegate -(void)textFieldDidEndEditing:(UITextField *)textField { __weak typeof(self) weakSelf = self; [self.discussTabV mas_updateConstraints:^(MASConstraintMaker *make) { make.left.equalTo(weakSelf.view); make.right.equalTo(weakSelf.view); make.top.equalTo(weakSelf.view); make.bottom.equalTo(weakSelf.view).with.offset(-SCREEN_WIDTH*100.f/750.f); }]; [_whiteV mas_updateConstraints:^(MASConstraintMaker *make) { make.left.equalTo(weakSelf.view); make.right.equalTo(weakSelf.view); make.height.mas_equalTo(SCREEN_WIDTH*100.f/750.f); make.bottom.equalTo(weakSelf.view); }]; }
移除通知:
-(void)dealloc { //移除通知 [[NSNotificationCenter defaultCenter] removeObserver:self]; }
效果展示:
點擊輸入時,界面不會整體上移! 僅僅是輸入框配合鍵盤上移!
參考:
《三方庫大全》:各種三方庫的介紹!
《三方庫的使用》:三方庫的使用
《CocoaPods》:CocoaPods介紹和使用
《Cocoapods導入 常用第三方庫》:使用Cocoapods導入三方庫
文章持續(xù)更新中~~
總結(jié)的文章全部分開了,以便總結(jié)!