IOS UIwebView 加载网络图片 使用相对地址

方法一:

  在html文件内直接使用file:///user//xx//image.png的绝对路径

  注:这样可以显示图片,但是如果在程序目录修改,图片就不能显示

方法二:

  在html使用占位符,如:在html内使用<image src="file:/[myimage]" height="200" width="320">

 在加载html文本的时候,replace这个占位符

 代码如下:

  string htmlpath=Path.GetFullPath("Docs/Detail.html");//根据html的相对路径获取html文件的绝对路径

  string htmltext=File.OpenText(htmlpath).ReadToEnd();//读取html的内容

  string  imagepath=Path.GetFullPath("Images/image.png").Replace("/","//").Replace(" ","%20");//读取图片的绝对路径后替换掉单斜杠和空格

  htmltext=htmltext.Replace("[myimage]",imagepath);//将html内容内的image占位符替换成正确的路径

  webview.LoadHtmlString(htmltext,null);//webview加载html内容

  注:如果图片过多则处理很麻烦,只能做例子写写,不能真正使用

方法三:

  使用webview.LoadHtmlString(htmltext,BaseUrl);//BaseUrl:sets the main page content and  base Url

  在方法三中,我们在html文件中图片地址只用使用相对地址了 <image src="Images/image.png" height="200" width="320">

  代码:

  NSUrl BaseUrl=new NSUrl(Path.GetFullPath("."),true);//获取程序的根目录路径

   webview.LoadHtmlString(htmltext,BaseUrl);//使用此重载方法的时候,图片的路径或自动处理成BaseUrl+image.src,这样图片就能正常显示了

 例如:

UIWebView *twoWebView =[[UIWebView alloc]initWithFrame:CGRectMake(0, 100, 200, 100)];

 jsString = [NSStringstringWithFormat:@"<html> \n"

                        "<head> \n"

                        "<style type=\"text/css\"> \n"

                        "body {font-size:%fpx; line-height:%fpx;background-color: transparent;}\n"

                        "</style> \n"

                        "</head> \n"

                        "<body>%@</body> \n"

                        "</html>"fontSize ,line_height,htmlText];

 NSURL *urlBai=[NSURLURLWithString:@"http://42.96.192.186"];

 [showWebView loadHTMLString:jsString baseURL:   urlBai];


[webView addSubview:twoWebView];

 

   注:在使用次方法的时候,html更容易处理,程序也容易处理

综述:在以上三种方法种,第三种方法最优

转载于:https://www.cnblogs.com/someonelikeyou/p/3539537.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值