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


相关推荐: Python正则表达式进阶教程_复杂匹配与分组替换解析  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  VIVO手机上del键无效OnKeyListener不响应的原因及解决方法  如何在Windows 2008云服务器安全搭建网站?  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  个人摄影网站制作流程,摄影爱好者都去什么网站?  瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口  如何选择PHP开源工具快速搭建网站?  Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性  Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  成都品牌网站制作公司,成都营业执照年报网上怎么办理?  如何在橙子建站中快速调整背景颜色?  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解  HTML透明颜色代码在Angular里怎么设置_Angular透明颜色使用指南【详解】  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  Laravel如何实现全文搜索功能?(Scout和Algolia示例)  如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】  Laravel怎么生成URL_Laravel路由命名与URL生成函数详解  如何在景安服务器上快速搭建个人网站?  Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  昵图网官网入口 昵图网素材平台官方入口  html5audio标签播放结束怎么触发事件_onended回调方法【教程】  如何快速生成凡客建站的专业级图册?  如何在IIS服务器上快速部署高效网站?  无锡营销型网站制作公司,无锡网选车牌流程?  大连 网站制作,大连天途有线官网?  高端云建站费用究竟需要多少预算?  如何批量查询域名的建站时间记录?  Laravel用户密码怎么加密_Laravel Hash门面使用教程  详解Android——蓝牙技术 带你实现终端间数据传输  Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑  INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】  手机网站制作与建设方案,手机网站如何建设?  如何在Windows虚拟主机上快速搭建网站?  如何在宝塔面板中创建新站点?  Python制作简易注册登录系统  如何用PHP工具快速搭建高效网站?  历史网站制作软件,华为如何找回被删除的网站?  Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践  夸克浏览器网页跳转延迟怎么办 夸克浏览器跳转优化  如何获取上海专业网站定制建站电话?  微信小程序 HTTPS报错整理常见问题及解决方案  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程