2016-05-0908:24:25 发表评论 0℃热度
写一些平时看书学习iOS的笔记,基础的、进阶的都有,供以后回顾,也可以让刚开始学习的同学学习。
- (void)loadRequest:(NSURLRequest *)request;
- (void)reload;
- (void)stopLoading;
- (void)goBack;
- (void)goForward;
@property(nonatomic) UIDataDetectorTypes dataDetectorTypes
@property(nonatomic,readonly,getter=canGoBack) BOOL canGoBack;
@property(nonatomic,readonly,getter=canGoForward) BOOL canGoForward;
@property(nonatomic,readonly,getter=isLoading) BOOL loading;
@property(nonatomic) BOOL scalesPageToFit;
成为UIWebView的代理,遵守UIWebViewDelegate协议,就能监听UIWebView的加载过程
- (void)webViewDidStartLoad:(UIWebView *)webView;
请求完毕(加载数据完毕)时调用这个方法
- (void)webViewDidFinishLoad:(UIWebView *)webView;
请求错误时调用这个方法
- (void)webView:(UIWebView *)webView didFailLoadWithError:(NSError *)error;
UIWebView在发送请求之前,都会调用这个方法,如果返回NO,代表停止加载请求,返回YES,代表允许加载请求
- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType;
alert(10); //弹框
document.getElementById(‘test’); //根据ID获得某个DOM元素
使用UIWebView的stringByEvaluatingJavaScriptFromString方法即可。
[self.webView goBack]; //回退
[self.webView goForward]; //前进
[self.webView reload]; //刷新
self.goBackBtn.enabled = webView.canGoBack;
self.fowardBtn.enabled = webView.canGoForward;
//设置网页自动适应
self.webView.scalesPageToFit = YES;
//设置检测网页中的格式类型,all表示检测所有类型包括超链接、电话号码、地址等。
self.webView.dataDetectorTypes = UIDataDetectorTypeAll;
self.webView.scrollView.contentInset = UIEdgeInsetsMake(50, 0, 0, 0);
每当将加载请求的时候调用该方法,返回YES 表示加载该请求,返回NO 表示不加载该请求
//可以在该方法中拦截请求
-(BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType
{
return ![request.URL.absoluteString containsString:@"dushu"];
}
//开始加载网页,不仅监听我们指定的请求,还会监听内部发送的请求
-(void)webViewDidStartLoad:(UIWebView *)webView
//网页加载完毕之后会调用该方法
-(void)webViewDidFinishLoad:(UIWebView *)webView
//网页加载失败调用该方法
-(void)webView:(UIWebView *)webView didFailLoadWithError:(NSError *)error
NSURL *url = [[NSBundle mainBundle] URLForResource:@"ithome.pdf" withExtension:nil];
[self.webView loadRequest:[NSURLRequest requestWithURL:url]];
3.2 HTML
1.Html决定网页的内容,css决定网页的样式,js决定网页的事件
2.html学习网站:W3School
NSString *str = [self.webView stringByEvaluatingJavaScriptFromString:@"sum()"];
新的需求:点击按钮的时候拨打电话
但是我在点击按钮的时候,用户是不知道的,我们怎么能够知道用户点击了网页上面的一个按钮,只能通过一个技巧,那就是自己搞一个特定的协议头比如说hbw:当我拦截到你的网络请求的时候,只需要判断一下当前的协议头是不是这个就能判断你现在是否是JS调用。
OC里面有通过字符串生成SEL类型的方法,所以当拿到数据之后做下面的事情
//判断字符串是否以一个固定的字符开头,这里为A
[@"abc" hasPrefix:@"A"]
//截串操作
- (NSString *)substringFromIndex:(NSUInteger)from;
//切割字符串,返回一个数组
- (NSArray<NSString *> *)componentsSeparatedByString:(NSString *)separator;
//替换操作
- (NSString *)stringByReplacingOccurrencesOfString:(NSString *)target withString:(NSString *)replacement
//把string包装成SEL
SEL selector = NSSelectorFromString(sel);
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Warc-performSelector-leaks"
//-Warc-performSelector-leaks为唯一的警告标识,这里面的代码可以去除警告
[self performSelector:selector withObject:nil];
#pragma clang diagnostic pop
在iOS中可以直接调用某个对象的消息方式有两种:
第一种方式比较简单,能完成简单的调用。但是对于>2个的参数或者有返回值的处理,那就需要做些额外工作才能搞定。那么在这种情况下,我们就可以使用NSInvocation来进行这些相对复杂的操作。
封装invacation可以调用多个参数的方法
-(void)invacation
{
//1.创建一个MethodSignature,签名中保存了方法的名称,参数和返回值
//这个方法属于谁,那么就用谁来进行创建
//注意:签名一般是用来设置参数和获得返回值的,和方法的调用没有太大的关系
NSMethodSignature *signature = [ViewController instanceMethodSignatureForSelector:@selector(callWithNumber:andContext:withStatus:)];
//注意不要写错了方法名称
NSMethodSignature *signature = [ViewController methodSignatureForSelector:@selector(call)];
//2.通过MethodSignature来创建一个NSInvocation
NSInvocation中保存了方法所属于的对象|方法名称|参数|返回值等等
NSInvocation *invocation = [NSInvocation invocationWithMethodSignature:signature];
//2.1 设置invocation,来调用方法
invocation.target = self;
invocation.selector = @selector(call);
invocation.selector = @selector(callWithNumber:);
invocation.selector = @selector(callWithNumber:andContext:);
invocation.selector = @selector(callWithNumber:andContext:withStatus:);
NSString *number = @"1761237846";
NSString *context = @"玩游戏";
NSString *status = @"上课的时候";
//注意:
//1.自定义的参数索引从2开始,0和1已经被self and _cmd占用了
//2.方法签名中保存的方法名称必须和调用的名称一致
[invocation setArgument:&number atIndex:2];
[invocation setArgument:&context atIndex:3];
[invocation setArgument:&status atIndex:4];
//3.调用invok方法来执行
[invocation invoke];
}
1.一般处理方式:
2.如何抛出异常
方式一
@throw [NSException exceptionWithName:@"程序异常" reason:@"异常原因:数组越界" userInfo:nil];
方式二
NSString *info = [NSString stringWithFormat:@"%@找不到方法",NSStringFromSelector(aSelector)];
下面这种方法是自动抛出的
[NSException raise:@"抛出异常" format:info,nil];
3.如何捕获异常
NSSetUncaughtExceptionHandler (&UncaughtExceptionHandler);
void UncaughtExceptionHandler(NSException *exception) {
NSArray *arr = [exception callStackSymbols];//得到当前调用栈信息
NSString *reason = [exception reason];//非常重要,就是崩溃的原因
NSString *name = [exception name];//异常类型
NSString *errorMsg = [NSString stringWithFormat:@"当前调用栈的信息:%@\nCrash的原因:%@\n异常类型:%@\n",arr,reason,name];
//把该信息保存到本地沙盒,下次回传给服务器。
}
void UncaughtExceptionHandler(NSException *exception) {
//获取异常崩溃信息
NSArray *callStack = [exception callStackSymbols];
NSString *reason = [exception reason];
NSString *name = [exception name];
NSString *content = [NSString stringWithFormat:@"========异常错误报告========\nname:%@\nreason:\n%@\ncallStackSymbols:\n%@",name,reason,[callStack componentsJoinedByString:@"\n"]];
//把异常崩溃信息发送至开发者邮件
NSMutableString *mailUrl = [NSMutableString string];
[mailUrl appendString:@"mailto:test@qq.com"];
[mailUrl appendString:@"?subject=程序异常崩溃,请配合发送异常报告,谢谢合作!"];
[mailUrl appendFormat:@"&body=%@", content];
//打开地址
NSString *mailPath = [mailUrl stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:mailPath]];
}