IOS ObjectC与javascript交互详解及实现代码

发布时间 - 2026-01-10 23:23:45    点击率:

IOS OC与js交互详解

JS注入 : 把JS代码有OC注入到网页

JS注入又叫做OC和JS的交互

OC和JS的交互需要一个桥梁(中介),这个桥梁就是UIWebView的代理方法

网页加载初始内容

#import "ViewController.h"

@interface ViewController ()<UIWebViewDelegate>

@property (weak, nonatomic) IBOutlet UIWebView *webView;

@end
- (void)viewDidLoad {
  [super viewDidLoad];
  // 设置webView的代理
  self.webView.delegate = self;

  // 加载网页数据
  NSURL *URL = [NSURL URLWithString:@"http://m.dianping.com/tuan/deal/5501525"];
//  NSURL *URL = [NSURL URLWithString:@"https://www.hao123.com/?tn=93321723_hao_pg"];
  NSURLRequest *request = [NSURLRequest requestWithURL:URL];
  [self.webView loadRequest:request];
}

在UIWebView的代理方法里用js来更改原生网页

/// 网页加载完成之后调用的代理方法 : JS注入 : OC调用JS代码
- (void)webViewDidFinishLoad:(UIWebView *)webView
{
  // 用于拼接JS代码的字符串
  NSMutableString *stringM = [NSMutableString string];

  // 拼接移除顶部导航的JS代码
  [stringM appendString:@"var headerTag = document.getElementsByTagName('header')[0]; headerTag.parentNode.removeChild(headerTag);"];
  // 拼接移除橙色按钮的JS代码
  [stringM appendString:@"var footerBtnTag = document.getElementsByClassName('footer-btn-fix')[0]; footerBtnTag.parentNode.removeChild(footerBtnTag);"];
  // 拼接移除底部布局的JS代码
  [stringM appendString:@"var footerTag = document.getElementsByClassName('footer')[0]; footerTag.parentNode.removeChild(footerTag);"];
  // 拼接给img标签添加点击事件的JS代码
  [stringM appendString:@"var imgTag = document.getElementsByTagName('figure')[0].children[0]; imgTag.onclick = function(){window.location.href='https://www.baidu.com'};"];

  // 这个方法就是UIWebView提供的.专门做JS注入的方法
  [webView stringByEvaluatingJavaScriptFromString:stringM];
}

拦截原生网络请求网页跳转

imgTag.onclick = function(){window.location.href='https://www.baidu.com‘} 

点击imgTag时,主动发送网络请求

主动发送网络请求的目的 : 就是为了让UIWebView能够拦截到我的自定义的URL

通过自定义的URL,判断 / 区别 我点击的标签是否是我设计的那个标签

自定义独一无二的URL,表示点击的是独一无二的标签

总结起来就是两步

第一步 : JS注入标签的点击事件,并主动发送一个自定义的URL的请求

第二步 : 在UIWebView里面.拦截自定义的URL的请求,然后判断请求

JS间接调用OC : JS和OC的交互

网页即将开始加载时调用的代理方法 : 可以拦截到webView上的所有的网络请求

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType
{
  // 获取拦截到的所有的请求
  NSString *URLString = request.URL.absoluteString;
  //https://m.baidu.com/?from=1015143h
  //  NSLog(@"%@",URLString);

  if ([URLString isEqualToString:@"https://m.baidu.com/?from=1015143h"]) {
    NSLog(@"我点击的是imgTag");

    // 当我知道点击的是imgTag时,自动push
    //http://www.csdn.net/

    NSURL *URL = [NSURL URLWithString:@"http://www.csdn.net/"];
    NSURLRequest *request = [NSURLRequest requestWithURL:URL];
    [self.webView loadRequest:request];
//    TestViewController *testVC = [[TestViewController alloc] init];
//    [self.navigationController pushViewController:testVC animated:YES];

    // 因为这个地址是无效地址.不需要加载的
    return NO;
  }

  // 返回YES的作用 : 表示你拦截到的请求,允许正常的发送出去;反之,不允许拦截到的请求发送出去
  return YES;
}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# iOS  # OC与js交互 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  Laravel Blade模板引擎语法_Laravel Blade布局继承用法  如何在Windows虚拟主机上快速搭建网站?  Python文件流缓冲机制_IO性能解析【教程】  Laravel定时任务怎么设置_Laravel Crontab调度器配置  百度输入法ai组件怎么删除 百度输入法ai组件移除工具  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  济南网站建设制作公司,室内设计网站一般都有哪些功能?  javascript中数组(Array)对象和字符串(String)对象的常用方法总结  如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】  如何在Tomcat中配置并部署网站项目?  Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  如何用腾讯建站主机快速创建免费网站?  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  使用豆包 AI 辅助进行简单网页 HTML 结构设计  活动邀请函制作网站有哪些,活动邀请函文案?  如何用免费手机建站系统零基础打造专业网站?  Laravel如何使用Sanctum进行API认证?(SPA实战)  Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】  Android okhttputils现在进度显示实例代码  Laravel如何使用Blade模板引擎?(完整语法和示例)  javascript中对象的定义、使用以及对象和原型链操作小结  西安专业网站制作公司有哪些,陕西省建行官方网站?  Laravel用户密码怎么加密_Laravel Hash门面使用教程  Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】  JS中页面与页面之间超链接跳转中文乱码问题的解决办法  移动端脚本框架Hammer.js  Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  网站页面设计需要考虑到这些问题  Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理  香港服务器如何优化才能显著提升网站加载速度?  北京的网站制作公司有哪些,哪个视频网站最好?  Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践  轻松掌握MySQL函数中的last_insert_id()  Laravel如何实现事件和监听器?(Event & Listener实战)  html5怎么画眼睛_HT5用Canvas或SVG画眼球瞳孔加JS控制动态【绘制】  Win11怎么开启自动HDR画质_Windows11显示设置HDR选项  百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】  Laravel如何使用Vite进行前端资源打包?(配置示例)  香港服务器网站卡顿?如何解决网络延迟与负载问题?  Laravel如何记录自定义日志?(Log频道配置)  如何在橙子建站中快速调整背景颜色?  php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】  Laravel如何使用Blade组件和插槽?(Component代码示例)  详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点  Laravel怎么使用Intervention Image库处理图片上传和缩放  如何快速生成橙子建站落地页链接?