zoukankan      html  css  js  c++  java
  • iOS UI基础-15.0 UIWebView

    WebView介绍

    知识点:

    • 代码创建一个UIWebView
    • OC调用html的js
    • js页面调用OC

    相关代码实现

    代码创建一个UIWebView

        // 1.webView
        UIWebView *webView = [[UIWebView alloc] init];
        webView.frame = self.view.bounds;
        webView.delegate = self;
        // 伸缩页面至填充整个webView
        webView.scalesPageToFit = YES;
        // 隐藏scrollView
        webView.scrollView.hidden = YES;
        [self.view addSubview:webView];
        
        // 2.加载网页
        NSURLRequest *request = [NSURLRequest requestWithURL:[NSURL URLWithString:@"http://m.dianping.com/tuan/deal/5501525"]];
        [webView loadRequest:request];

    OC调用html的js

    关键代码:

        //  删除底部的链接的JS
        [js1 appendString:@"var footer = document.getElementsByTagName('footer')[0];"];
        [js1 appendString:@"footer.parentNode.removeChild(footer);"];
        // OC中调用js
        [webView stringByEvaluatingJavaScriptFromString:js1];

    完整示例

    创建一个webView,实现UIWebViewDelegate代理,在页面加载完毕后,通过js删除相关的html代码。

    #import "HMViewController.h"
    
    @interface HMViewController () <UIWebViewDelegate>
    @property (nonatomic, weak) UIActivityIndicatorView *loadingView;
    @end
    
    @implementation HMViewController
    
    /**
     test.html存在于服务器,里面的html和js代码,我们是无法修改的
     如果test.html显示在手机端,把那个ul去掉
     */
    
    - (void)viewDidLoad
    {
        [super viewDidLoad];
        // 1.webView
        UIWebView *webView = [[UIWebView alloc] init];
        webView.frame = self.view.bounds;
        webView.delegate = self;
        // 伸缩页面至填充整个webView
        webView.scalesPageToFit = YES;
        // 隐藏scrollView
        webView.scrollView.hidden = YES;
        [self.view addSubview:webView];
        
        // 2.加载网页
        NSURLRequest *request = [NSURLRequest requestWithURL:[NSURL URLWithString:@"http://m.dianping.com/tuan/deal/5501525"]];
        [webView loadRequest:request];
        
        // 3.创建一个加载蒙板
        UIActivityIndicatorView *loadingView = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleWhiteLarge];
        [loadingView startAnimating];
        loadingView.center = CGPointMake(160, 240);
        [self.view addSubview:loadingView];
        self.loadingView = loadingView;
    }
    
    // OC -> JS
    // 在OC中调用JS
    
    #pragma mark - UIWebViewDelegate
    - (void)webViewDidFinishLoad:(UIWebView *)webView
    {
        // 执行JS代码,将大众点评网页里面的多余的节点删掉
        NSMutableString *js1 = [NSMutableString string];
        // 0.删除顶部的导航条
        [js1 appendString:@"var header = document.getElementsByTagName('header')[0];"];
        [js1 appendString:@"header.parentNode.removeChild(header);"];
        
        // 1.删除底部的链接
        [js1 appendString:@"var footer = document.getElementsByTagName('footer')[0];"];
        [js1 appendString:@"footer.parentNode.removeChild(footer);"];
        // OC中调用js
        [webView stringByEvaluatingJavaScriptFromString:js1];
        
        dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.25 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
            NSMutableString *js2 = [NSMutableString string];
            // 2.删除浮动的广告
            [js2 appendString:@"var list = document.body.childNodes;"];
            [js2 appendString:@"var len = list.length;"];
            [js2 appendString:@"var banner = list[len - 1];"];
            [js2 appendString:@"banner.parentNode.removeChild(banner);"];
            [webView stringByEvaluatingJavaScriptFromString:js2];
            
            // 显示scrollView
            webView.scrollView.hidden = NO;
            
            // 删除圈圈
            [self.loadingView removeFromSuperview];
        });
    }
    
    @end

    js页面调用OC

    oc加载的页面中,url链接跳转及请求,都会被shouldStartLoadWithRequest这个代理方法拦截,因而,我们在这里做处理。

    html页面和oc两方都协商好,使用一个头文件来定义一个url链接请求,如:

     // 调用OC中call方法
     window.location.href = 'hm://call';

    hm:// 就是相应的头文件了。接着,通过截取字符串的方式,来判断头文件是“hm://”开头的就是请求oc代码

    具体代码实现。

    test.html

    <!DOCTYPE html>
    <html>
        <head lang="en">
            <meta charset="UTF-8">
        </head>
        <body>
            <div>
                <button onclick="fn_open_camera();">拍照</button>
            </div>
            <div>
                <button onclick="fn_call();">打电话</button>
            </div>
            <a href="http://www.baidu.com">百度</a>
            <script>
                function fn_call() {
                    // 调用OC中call方法
                    window.location.href = 'hm://call';
                }
            
            function fn_open_camera() {
                // 调用OC中openCamera方法
                window.location.href = 'hm://openCamera';
            }
            </script>
        </body>
    </html>

    oc相关代码

    #import "HMViewController.h"
    
    @interface HMViewController () <UIWebViewDelegate>
    @end
    
    @implementation HMViewController
    
    - (void)viewDidLoad
    {
        [super viewDidLoad];
        // 1.webView
        UIWebView *webView = [[UIWebView alloc] init];
        webView.frame = self.view.bounds;
        webView.delegate = self;
        [self.view addSubview:webView];
        
        // 2.加载网页
        NSURL *url = [[NSBundle mainBundle] URLForResource:@"test" withExtension:@"html"];
        NSURLRequest *request = [NSURLRequest requestWithURL:url];
        [webView loadRequest:request];
    }
    
    #pragma mark - UIWebViewDelegate
    /**
     *  webView每当发送一个请求之前,都会先调用这个方法(能拦截所有请求)
     */
    - (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType
    {
        NSString *url = request.URL.absoluteString;
        NSRange range = [url rangeOfString:@"hm://"];
        NSUInteger loc = range.location;
        if (loc != NSNotFound) { // url的协议头是hm
            // 方法名
            NSString *method = [url substringFromIndex:loc + range.length];
            
            // 转成SEL
            SEL sel = NSSelectorFromString(method);
            [self performSelector:sel withObject:nil];
        }
        return YES;
    }
    
    /**
     *  打电话
     */
    - (void)call
    {
        NSLog(@"call----");
    }
    
    /**
     *  打开照相机
     */
    - (void)openCamera
    {
        NSLog(@"openCamera----");
    }
    
    @end

    上面这样就实现了,点击拍照和打开照相机,都会调用oc代码,而点击百度,则跳到百度的页面。

    网易新闻详情

    #import "HMViewController.h"
    
    @interface HMViewController ()
    
    @end
    
    @implementation HMViewController
    
    - (void)viewDidLoad
    {
        [super viewDidLoad];
        
        // 1.url
        // http://c.m.163.com/nc/article/A7A94MCL00963VRO/full.html
        NSURL *url = [NSURL URLWithString:@"http://c.m.163.com/nc/article/A7AQOT560001124J/full.html"];
        
        // 2.requets
        NSURLRequest *request = [NSURLRequest requestWithURL:url];
        
        // 3.发送请求
        [NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
            NSDictionary *dict = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableLeaves error:nil];
            NSDictionary *news = dict[@"A7AQOT560001124J"];
            [self showNews:news];
        }];
    }
    
    - (void)showNews:(NSDictionary *)news
    {
        // 1.取出网页内容
        NSString *body = news[@"body"];
        
        // 2.取出图片
        NSDictionary *img = [news[@"img"] lastObject];
        NSString *imgHTML = [NSString stringWithFormat:@"<img src="%@" width="300" height="171">", img[@"src"]];
        
        // 2.创建一个webView,显示网页
        UIWebView *webView = [[UIWebView alloc] init];
        webView.frame = self.view.bounds;
        [self.view addSubview:webView];
        
        // 3.拼接网页内容
        NSString *html = [body stringByReplacingOccurrencesOfString:img[@"ref"] withString:imgHTML];
        
        // 4.取出新闻标题
        NSString *title = news[@"title"];
        // 5.取出新闻的时间
        NSString *time = news[@"ptime"];
        
        // 头部内容
        NSString *header = [NSString stringWithFormat:@"<div class="title">%@</div><div class="time">%@</div>", title, time];
        html = [NSString stringWithFormat:@"%@%@", header, html];
        
        // 链接mainBundle中的CSS文件
        NSURL *cssURL = [[NSBundle mainBundle] URLForResource:@"news" withExtension:@"css"];
        html = [NSString stringWithFormat:@"%@<link rel="stylesheet" href="%@">", html, cssURL];
        
        // 5.加载网页内容
        [webView loadHTMLString:html baseURL:nil];
    }
    
    @end

    UIWebView加载POST请求

    NSURL *url = [NSURL URLWithString: @"http://your_url.com"];
    NSString *body = [NSString stringWithFormat: @"arg1=%@&arg2=%@", @"val1",@"val2"]; 
    NSMutableURLRequest *request = [[NSMutableURLRequest alloc]initWithURL: url]; [request setHTTPMethod: @"POST"]; [request setHTTPBody: [body dataUsingEncoding: NSUTF8StringEncoding]]; [webView loadRequest: request]
  • 相关阅读:
    今天整理了一下博客文章
    让我们猜猜明天凌晨一点NASA会有什么重大消息公布?
    微软2010 PDC Party郑州社区行
    记一次Shiro反序列化到远程桌面
    从公有云到渗透进内网漫游
    华为云CTF cloud非预期解之k8s渗透实战
    记一次任意文件下载到getshell
    记一次失败的实战渗透
    Subversion for Windows 安装配置
    使用Fiddler2录制HTTP操作脚本
  • 原文地址:https://www.cnblogs.com/jys509/p/4832426.html
Copyright © 2011-2022 走看看