cell嵌套UIWebView遇到的几个问题
一、防止死循环问题
方法一:使用动画块 [self.myTableView beginUpdates];[self.myTableView endUpdates];
在下面的代理方法获取内容的高度,然后刷新
-(void)webViewDidFinishLoad:(UIWebView *)webView
{
webHeight = [[webView stringByEvaluatingJavaScriptFromString:@"document.body.offsetHeight;"] floatValue];//次高度就是cell的高度
CGSize actualSize = [webView sizeThatFits:CGSizeZero];
CGRect newFrame = webView.frame;
newFrame.size.height = actualSize.height;
webView.frame = newFrame;
[self.myTableView beginUpdates];
[self.myTableView endUpdates];
}
方法二:将webview创建为全局的,在数据请求之后再加载数据 : [_webView loadHTMLString:content baseURL:baseUrl];
tableview代理方法中:-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
NSString *cellIdentifier = @"webCell";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:cellIdentifier];
if (!cell) {
cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:cellIdentifier];
if (!_webView){
_webView = [[UIWebView alloc]initWithFrame:CGRectMake(10, 10.0, MainScreen_width-20.0, 1)];
_webView.delegate = self;
_webView.scrollView.scrollEnabled = NO;
[_webView sizeToFit];
[cell addSubview:_webView];
}
}
cell.backgroundColor = [UIColor clearColor];
cell.selectionStyle = UITableViewCellSelectionStyleNone;
return cell;
}
在webview的代理方法中可以直接使用tableview的reloadData方法
-(void)webViewDidFinishLoad:(UIWebView *)webView
{
webHeight = [[webView stringByEvaluatingJavaScriptFromString:@"document.body.offsetHeight;"] floatValue];//次高度就是cell的高度
CGSize actualSize = [webView sizeThatFits:CGSizeZero];
CGRect newFrame = webView.frame;
newFrame.size.height = actualSize.height;
webView.frame = newFrame;
[self.myTableView reloadData];
}
二、js交互问题
向h5页面注入js的方法: [webView stringByEvaluatingJavaScriptFromString:jsstr];//注入js方法 可以通过次方法向h5页面注入js方法,来操作h5页面
例如:-(void)webViewDidFinishLoad:(UIWebView *)webView
{
//这里是js,主要目的实现对url的获取
static NSString *const jsGetImages =
@"function getImages(){\ var objs = document.getElementsByTagName(\"img\");\
var imgScr = '';\
for(var i=0;i<objs.length;i++){\
var _src = '';\
_src = objs[i].getAttribute('data-echo');\
if( _src == null)\
_src = objs[i].src;\
if(i != (objs.length-1))\
imgScr = imgScr + _src + '+';\
};\
return imgScr;\
};";
[webView stringByEvaluatingJavaScriptFromString:jsGetImages];//注入js方法
NSString *urlResurlt = [webView stringByEvaluatingJavaScriptFromString:@"getImages()"];//调用js方法
}
三、html图片懒加载,适配webview的高度,参考:http://www.cnblogs.com/wangyingblock/articles/5718916.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· AI 智能体引爆开源社区「GitHub 热点速览」