iOS记录

注意点

1、使用ALAssetsLibrary需要强引用。

2、使用changeDetailsForFetchResult:时,PHFetchResult要强引用。

3、textField相关
 3.1、textField右对齐状态下,输入空格后,光标跳转至左侧。
 3.2、textField右对齐状态下,手写输入会产生一个中文空格。
 3.3、直接对textField.text赋值光标会跳到右侧。
 3.4、textField:shouldChangeCharactersInRange:replacementString:方法在iOS10之前输入中文不会触发。
 3.5、textField右对齐状态下,在光标前面无字符的情况下,无法输入空格,需使用\u00a0替代。

4、使用ALAssetsLibrary获取到image后直接使用,当在PC端删除图片并在手机端使用Layer动画时,Cell会闪烁。

5、转场动画过程中截屏需使用GCD,否则有可能会有黑屏。

// To avoid a blank snapshot, defer snapshotting the incoming view until it
// has had a chance to perform layout and drawing (1 run-loop cycle).
dispatch_async(dispatch_get_main_queue(), ^{
    UIGraphicsBeginImageContextWithOptions(containerView.bounds.size, YES, containerView.window.screen.scale);
    [toView drawViewHierarchyInRect:containerView.bounds afterScreenUpdates:NO];
    toViewSnapshot = UIGraphicsGetImageFromCurrentImageContext();
    UIGraphicsEndImageContext();
});

6、删除cookie

NSHTTPCookieStorage *storage = [NSHTTPCookieStorage sharedHTTPCookieStorage];
NSArray *cookies =  [[storage cookies] copy];

for (NSHTTPCookie *cookie in cookies) {
    [storage deleteCookie:cookie];
}

7、web认证
UIWebView:使用NSURLConnection
WKWebView:使用

- (void)webView:(WKWebView *)webView didReceiveAuthenticationChallenge:(NSURLAuthenticationChallenge *)challenge completionHandler:(void (^)(NSURLSessionAuthChallengeDisposition, NSURLCredential *))completionHandler  {
}

8、使用FLEX时,在转场动画时旋转屏幕,
iOS8状态栏会跟着转
iOS9以上,屏幕会一起转,出现黑屏

9、

NSString *someString = nil;
if (NSNotFound != [someString rangeOfString:@"swift"].location) {
    NSLog(@"Someone mentioned swift!");
}

如果 someString 是 nil,那么 rangeOfString: 消息将返回一个值都为零的NSRange。也就是说.location 将为零,而 NSNotFound 被定义为 NSIntegerMax。这样一来,当 someString 是 nil 时,if 语句的内容将被执行。

小技巧

1、横屏显示状态栏
非刘海屏:

[[UIApplication sharedApplication] setStatusBarHidden:YES withAnimation:UIStatusBarAnimationNone];
[[UIApplication sharedApplication] setStatusBarHidden:NO withAnimation:UIStatusBarAnimationNone];

刘海屏:
暂时没有办法,下图是苹果给的答复。


WechatIMG381.jpeg

2、设置UserAgent

[self.webViewAdapter stringByJavaScriptFromString:@"navigator.userAgent" handler:^(id  _Nonnull result) {
    NSString *appCurVersion = [[[NSBundle mainBundle] infoDictionary] objectForKey:@"CFBundleShortVersionString"];
    NSString *UserAgentValue = [NSString stringWithFormat:@"XXX %@ %@", appCurVersion, result];
    NSDictionary *dictionary = [[NSDictionary alloc] initWithObjectsAndKeys:UserAgentValue, @"UserAgent", nil];
    [[NSUserDefaults standardUserDefaults] registerDefaults:dictionary];
    [[NSUserDefaults standardUserDefaults] synchronize];
    ws.webViewAdapter = nil;
}];

3、设置textField光标位置

@interface UITextField (Cursor)

- (NSInteger)cursorIndex;
- (void)setCursorIndex:(NSInteger)index;

@end

@implementation UITextField (Cursor)

- (NSInteger)cursorIndex {
    
    UITextPosition *beginning = self.beginningOfDocument;
    UITextRange *selectedRange = self.selectedTextRange;
    UITextPosition *selectionStart = selectedRange.start;
    
    return [self offsetFromPosition:beginning toPosition:selectionStart];
}

- (void)setCursorIndex:(NSInteger)index {
    
    UITextPosition *beginning = self.beginningOfDocument;
    UITextPosition *position = [self positionFromPosition:beginning offset:index];
    UITextRange *selectionRange = [self textRangeFromPosition:position toPosition:position];
    
    [self setSelectedTextRange:selectionRange];
}

@end

4、判断字符串是否包含Emoji

@interface NSString (Emoji)

+ (BOOL)stringContainsEmoji:(NSString *)string;

@end

@implementation NSString (Emoji)

+ (BOOL)stringContainsEmoji:(NSString *)string {
    
    __block BOOL containsEmoji = NO;
    [string enumerateSubstringsInRange:NSMakeRange(0, [string length])
                             options:NSStringEnumerationByComposedCharacterSequences
                          usingBlock:^(NSString *substring, NSRange substringRange, NSRange enclosingRange, BOOL *stop) {
                              
         const unichar hs = [substring characterAtIndex:0];
         // surrogate pair
         if (0xd800 <= hs && hs <= 0xdbff) {
             if (substring.length > 1) {
                 const unichar ls = [substring characterAtIndex:1];
                 const int uc = ((hs - 0xd800) * 0x400) + (ls - 0xdc00) + 0x10000;
                 if (0x1d000 <= uc && uc <= 0x1f9c0) {
                     containsEmoji = YES;
                 }
             }
         } else if (substring.length > 1) {
             const unichar ls = [substring characterAtIndex:1];
             if (ls == 0x20e3 || ls == 0xfe0f || ls == 0xd83c) {
                 containsEmoji = YES;
             }
         } else {
             // non surrogate
             if (0x2100 <= hs && hs <= 0x278a) {
                 containsEmoji = YES;
             } else if (0x2793 <= hs && hs <= 0x27ff) {
                 containsEmoji = YES;
             } else if (0x2B05 <= hs && hs <= 0x2b07) {
                 containsEmoji = YES;
             } else if (0x2934 <= hs && hs <= 0x2935) {
                 containsEmoji = YES;
             } else if (0x3297 <= hs && hs <= 0x3299) {
                 containsEmoji = YES;
             } else if (hs == 0xa9 || hs == 0xae || hs == 0x303d || hs == 0x3030 || hs == 0x2b55 || hs == 0x2b1c || hs == 0x2b1b || hs == 0x2b50) {
                 containsEmoji = YES;
             }
         }
         if (containsEmoji) {
             *stop = YES;
         }
     }];
    
    return containsEmoji;
}

@end

5.1、给WKWebView添加Cookie

NSMutableURLRequest *mutableURLRequest = [[NSMutableURLRequest alloc] initWithURL:request.URL];
NSString *cookie = [self p_getCurrentCookieWithUrl:request.URL];
if (![cookie isEqualToString:@""]) {
    [mutableURLRequest addValue:cookie forHTTPHeaderField:@"Cookie"];
}

[self.wkWebView loadRequest:mutableURLRequest];

- (NSString *)p_getCurrentCookieWithUrl:(NSURL *)url {
    
    NSMutableString *cookieStr = [[NSMutableString alloc] init];
    NSArray *array =  [[NSHTTPCookieStorage sharedHTTPCookieStorage] cookiesForURL:url];
    
    if ([array count] > 0) {
        for (NSHTTPCookie *cookie in array) {
            [cookieStr appendFormat:@"%@=%@;",cookie.name, cookie.value];
        }
        [cookieStr deleteCharactersInRange:NSMakeRange(cookieStr.length - 1, 1)];
    }
    
    return cookieStr;
}

6、使用动态阈值加载数据

- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
    
    CGFloat threshold = 0.7;
    CGFloat itemPerPage = 10;
    
    CGFloat current = scrollView.contentOffset.y + scrollView.frame.size.height;
    CGFloat total = scrollView.contentSize.height;
    CGFloat ratio = current / total;
    
    CGFloat needRead =  [self.dataArray count] - itemPerPage * (1 - threshold) + 1;
    CGFloat totalItem = [self.dataArray count] + 1;
    CGFloat newThreshold = needRead / totalItem;
    
    if (ratio >= newThreshold) {
        // load next page

    }
}

7、查看源码

clang -rewrite-objc main.m

8、升级了Xcode并且改了名

sudo xcode-select -switch /Applications/Xcode8.3.app/Contents/Developer

9、WKWebview中部分链接无法打开

- (WKWebView *)webView:(WKWebView *)webView createWebViewWithConfiguration:(WKWebViewConfiguration *)configuration forNavigationAction:(WKNavigationAction *)navigationAction windowFeatures:(WKWindowFeatures *)windowFeatures {
    
    if (!navigationAction.targetFrame) {
        [webView loadRequest:navigationAction.request];
    }
    return nil;
}

10、安装cocoapods

sudo gem install -n /usr/local/bin cocoapods

11、获取当前的Wifi名

- (NSString *)getCurrentWifiHotSpotName {
    
    NSString *wifiName = nil;
    NSArray *ifs = (__bridge_transfer id)CNCopySupportedInterfaces();
    for (NSString *ifnam in ifs) {
        NSDictionary *info = (__bridge_transfer id)CNCopyCurrentNetworkInfo((__bridge CFStringRef)ifnam);
        if (info[@"SSID"]) {
            wifiName = info[@"SSID"];
        }
    }
    return wifiName;
}

12、连接Wifi(iOS 11)
1)打开Capabilities中的Hotspot Configuration

An application that needs access to the NEHotspotConfiguration API must have
the “com.apple.developer.networking.HotspotConfiguration” entitlement.

2)连接代码

if (@available(iOS 11.0, *)) {
    NEHotspotConfiguration *hotspotConfig = [[NEHotspotConfiguration alloc] initWithSSID:@"123" passphrase:@"12356789" isWEP:NO];
    
    NEHotspotConfigurationManager *hotspotManager = [NEHotspotConfigurationManager sharedManager];
    
    [hotspotManager applyConfiguration:hotspotConfig completionHandler:^(NSError * _Nullable error) {
        NSLog(@"%@", error ? : @"Success");
    }];
} else {
    NSLog(@"系统版本低于iOS 11.");
}

未完待续 、

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

推荐阅读更多精彩内容