ios开发之webView.scalesPageToFit = YES后 加载页面遇见表格显示很小的解决方法

来源:互联网 发布:来自网络用英语怎么说 编辑:程序博客网 时间:2024/05/23 01:21

ios开发之webView.scalesPageToFit = YES后 加载页面遇见表格显示很小的解决方法

在ios加载web时候,遇见加载列表的时候,当webView.scalesPageToFit = YES打开后,如果遇见加载模版后显示内容因为表格很小的问题,



写东西碰到问题,简单做了一个html页面,想放到UIWebView中,希望实现显示iPhone分辨率的大小

设置Web页面试用手机浏览器(iphone)

如果WEB页面没有经过特殊处理,在iphone浏览器上看页面会变的很小。可以在HEAD里用 META设置页面试用iphone浏览器, 设置如下:

以后做web app可以按照这个来做,增加以下内容ok :


设定HTML页面分辨率适应iOS设备的UIWebView

<meta content="width=device-width, initial-scale=1.0, maximum-scale=3.0, user-scalable=0;" name="viewport" />

width=device-width:设置宽度为手机设备屏宽,iphone 是 320;

initial-scale=1.0: 相对width,初始放大倍数;

maximum-scale=3.0:用户可最大放大倍数;

 user-scalable=0:是否允许用户是放大。



然后Xcode里加一行:webView.scalesPageToFit = YES 就可以实现放缩


<meta name="format-detection" content="telephone=no" />

/*设置web里面数字不能拨打电话*/


UIWebView可以让你创建一个网页浏览器,类似safari,而不是在程序中启动safsri哦。是不是觉得很棒呢?废话少说,切入正题。

一、创建UIWebView

 

  1. CGRect bouds = [[UIScreen manScreen]applicationFrame];  

  2. UIWebView* webView = [[UIWebView alloc]initWithFrame:bounds];  

二、设置属性

 

 

  1. webView.scalespageToFit = YES;//自动对页面进行缩放以适应屏幕  

  2. webView.detectsPhoneNumbers = YES;//自动检测网页上的电话号码,单击可以拨打  


三、显示网页视图UIWebView

  1. [self.view addSubview:webView];  

四、加载内容

 

 

  1. NSURL* url = [NSURL URLWithString:@"http://www.youku.com"];//创建URL  

  2. NSURLRequest* request = [NSURLRequest requestWithURL:url];//创建NSURLRequest  

  3. [webView loadRequest:request];//加载  

也可以加载一个本地资源:

 

 

  1. NSURL* url = [NSURL   fileURLWithPath:filePath];//创建URL  

  2. NSURLRequest* request = [NSURLRequest requestWithURL:url];//创建NSURLRequest  

  3. [webView loadRequest:request];//加载  


UIWebView 还支持将一个NSString对象作为源来加载。你可以为其提供一个基础URL,来指导UIWebView对象如何跟随链接和加载远程资源:

 

 

  1. [webView loadHTMLString:myHTML baseURL:[NSURL URLWithString:@"http://baidu.com"]];  

五、导航

UIWebView类内部会管理浏览器的导航动作,通过goForward和goBack方法你可以控制前进与后退动作:

 

 

  1. [webView goBack];  

  2. [webView goForward];  

  3. [webView reload];//重载  

  4. [webView stopLoading];//取消载入内容  

六、UIWebViewDelegate委托代理

UIWebView支持一组委托方法,这些方法将在特定时间得到通知。要使用这些方法,必须先设定webView的委托:

 

 

  1. webView.delegate = self;  

下面每个委托方法的第一个参数都是指向一个UIwebview的指针,因此你可以将一个委托用于多个网页视图。

 

 

  1. -(BOOL)webView:(UIWebView*)webView shouldStartLoadWithRequest:(NSURLRequest*) reuqest navigationType:(UIWebViewNavigationType)navigationType;//当网页视图被指示载入内容而得到通知。应当返回YES,这样会进行加载。通过导航类型参数可以得到请求发起的原因,可以是以下任意值:  

  2. UIWebViewNavigationTypeLinkClicked  

  3. UIWebViewNavigationTypeFormSubmitted  

  4. UIWebViewNavigationTypeBackForward  

  5. UIWebViewNavigationTypeReload  

  6. UIWebViewNavigationTypeFormResubmitted  

  7. UIWebViewNavigationTypeOther  

  1. -(void)webViewDidStartLoad:(UIWebView*)webView ;//当网页视图已经开始加载一个请求后,得到通知。  

  1. -(void)webViewDidFinishLoad:(UIWebView*)webView ;//当网页视图结束加载一个请求之后,得到通知。  

  1. -(void)webView:(UIWebView*)webView  DidFailLoadWithError:(NSError*)error;//当在请求加载中发生错误时,得到通知。会提供一个NSSError对象,以标识所发生错误类型。

1 0
原创粉丝点击