iOS app中无网络页面的添加方法详解

前言

大家应该都会遇到这样一个需求,在开发app的过程中,为了能有更好的用户体验,往往会加入没有网络时的页面展示,告诉用户当前的网络状态不可用,那么具体如何来实现实时监测网络状态的呢,就是我们接下来要讨论的问题了。话不多说了,来一起看看详细的介绍吧。

实现思路

我的实现思路大致如下:采用第三方库RealReachability监听网络状态的变化,然后在基类中添加监听,然后在基类中提供对外的方法,用来判断当前的网络状态,以便子类可以在不同的网络状态时做出对应的操作。最后自定义一个无网络界面,在没有链接网络时,添加到界面上,有网络时重新进行数据请求,并移除无网络界面即可。

具体操作
1.项目中添加第三方库—— RealReachability,这里我就不多做介绍,大家应该都会添加,不会的可以点此,这里会有比较详细的说明;

2.在appdelegate开启全局网络监测,具体代码如下:

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
 //开启网络监测
 [GLobalRealReachability startNotifier];
 return YES;
}

3.定义一个枚举,用来表示网络链接的三种状态,同时定义一个变量,用来判断当前的网络状态,具体如下:

typedef NS_ENUM(NSUInteger, XSWNetWorkStatus) {

 XSWNetWorkStatusNoInternet,//没有网络
 XSWNetWorkStatusFlow,//流量连接
 XSWNetWorkStatusWifi //wifi链接
};
//网络状态
@property (nonatomic,assign) XSWNetWorkStatus netStatus;

4.在基类中给通过RealReachability 给netStatus变量赋值,并添加监听,用来监测网络状态的变化,具体操作如下:

RealReachability *reachability = [RealReachability sharedInstance];
 ReachabilityStatus status = [reachability currentReachabilityStatus];
 switch (status) {
  case 0:
  {
   _netStatus = XSWNetWorkStatusNoInternet;
  }
   break;
  case 1:{

   _netStatus = XSWNetWorkStatusFlow;
  }
   break;
  case 2:{

   _netStatus = XSWNetWorkStatusWifi;
  }
   break;
  default:
   break;
 }
 //监听网络状态
 [[NSNotificationCenter defaultCenter] addObserver:self
selector:@selector(networkChanged:)
name:kRealReachabilityChangedNotification
object:nil];

5.实现监听回调事件,给netStatus赋值,并提供对外的方法,便于子类对不同的网络状态的处理,具体操作如下:

#pragma mark ==================监听事件的回调==================
- (void)networkChanged:(NSNotification *)notification
{
  RealReachability *reachability = (RealReachability *)notification.object;
  ReachabilityStatus status = [reachability currentReachabilityStatus];
  switch (status) {
    case 0:
    {
      _netStatus = XSWNetWorkStatusNoInternet;
      [self monitorNetStateChanged:0];
    }
      break;
    case 1:{
      _netStatus = XSWNetWorkStatusFlow;
      [self monitorNetStateChanged:1];
    }
      break;
    case 2:{
      _netStatus = XSWNetWorkStatusWifi;
      [self monitorNetStateChanged:2];
    }
      break;
    default:
      break;
  }
}
#pragma mark ==================网络状态改变==================
-(void)monitorNetStateChanged:(NSInteger)netState {

  //子类实现
}

子类重写monitorNetStateChanged:(NSInteger)netState方法,针对当前的网络状态,做出相应的操作即可,具体代码如下:

#pragma mark ==================网络状态的判断==================
-(void)monitorNetStateChanged:(NSInteger)netState {
  if (netState == 0) {
    //没有网络 展示没有网络界面,或是提示用户当前网络状态不可用
  }else{
    //有网,移除无网络界面,重新进行数据请求
  }
}

至此,没有网络界面的添加就说完了,如果大家有更好的实现方法或者是对我说的方法有任何的疑问,欢迎留言,我会在第一时间回复大家。最后,将我写的一个小demo附上,点此查看,也可以通过本地下载。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。

(0)

相关推荐

  • iOS app中无网络页面的添加方法详解

    前言 大家应该都会遇到这样一个需求,在开发app的过程中,为了能有更好的用户体验,往往会加入没有网络时的页面展示,告诉用户当前的网络状态不可用,那么具体如何来实现实时监测网络状态的呢,就是我们接下来要讨论的问题了.话不多说了,来一起看看详细的介绍吧. 实现思路 我的实现思路大致如下:采用第三方库RealReachability监听网络状态的变化,然后在基类中添加监听,然后在基类中提供对外的方法,用来判断当前的网络状态,以便子类可以在不同的网络状态时做出对应的操作.最后自定义一个无网络界面,在没有

  • 微信APP生命周期及页面生命周期示例详解

    目录 官方文档 小程序的启动流程 app生命周期 页面的生命周期 页面的生命周期(图) 官方文档 https://developers.weixin.qq.com/doc/search.html?query=生命周期&doc_type=miniprogram&jumpbackUrl=%2Fdoc%2F 小程序的启动流程 我们画一个图来表示一下,整个小程序的启动流程,我们就知道了: app生命周期 执行App()函数也就是注册一个App 1 在注册app的时候,可以判断小程序的进入场景 2

  • PHP中filter函数校验数据的方法详解

    介绍PHP中filter函数校验数据的方法详解,PHP过滤器包含两种类型:Validation用来验证验证项是否合法 .Sanitization用来格式化被验证的项目,因此它可能会修改验证项的值,将不合法的字符删除. input_filters_list() 用来列出当前系统所支持的所有过滤器. 复制代码 代码如下: <?php foreach(filter_list() as $id => $filter) {     echo $filter.' '.filter_id($filter).

  • vue2中引用及使用 better-scroll的方法详解

    使用时有三个要点: 一:html部分 <div class="example" ref="divScroll"> <div> <p>内容1</p> <p>内容2</p> <ul> <li>list1</li> <li>list2</li> <ul> </div> </div> [注] 1.最外层加re

  • ASP.NET Core中Razor页面的Handlers处理方法详解

    简介 在前一篇文章中,我们讨论了Razor页面.今天我们来谈谈处理方法(Handlers). 我们知道可以将代码和模型放在 .cshtml 文件里面或与 .cshtml 匹配的 .cshtml.cs 文件中. Razor页面处理程序或处理方法将用户请求匹配到我们的方法:请求来自 **.cshtml **文件. Razor页面遵循特定的命名约定.从上一篇文章可以看出,.NET Core开发工具自动生成了很多处理方法,例如下面这些: OnGet OnPost OnGetAsync OnPostAsy

  • Python实现向PPT中插入表格与图片的方法详解

    目录 插入表格 插入图片 上一章节学习了如何在 PPT 中添加段落以及自定义段落(书写段落的内容以及样式的调整),今天的章节将学习在 PPT 中插入表格与图片以及在表格中插入内容. 废话不多说了,直接进入主题. 插入表格 首先还是要生成 PPT 对象: ppt = Presentation() 通过 Presentation() 实例化一个 ppt 对象(Presentation 可以通过 python-pptx 直接拿过来使用) 选择布局: layout = ppt.slide_layout[

  • Python实现在图像中隐藏二维码的方法详解

    目录 一.前言 二.隐写 三.位平面分解 3.1 图像 3.2 位平面 3.3 位平面分解 3.4 位平面合成 四.图像隐写 一.前言 在某个App中有一个加密水印的功能,当帖子的主人开启了之后.如果有人截图,那么这张截图中就是添加截图用户.帖子ID.截图时间等信息,而且我们无法用肉眼看出这些水印. 这可以通过今天要介绍的隐写技术来实现,我们会通过这种技术,借助Python语言和OpenCV模块来实现在图像中隐藏二维码的操作.而且这个二维码无法通过肉眼看出. 二.隐写 隐写是一种类似于加密却又不

  • js基础之DOM中document对象的常用属性方法详解

    -----引入 每个载入浏览器的 HTML 文档都会成为 Document 对象. Document 对象使我们可以从脚本中对 HTML 页面中的所有元素进行访问. 属性 1  document.anchors  返回对文档中所有 Anchor 对象的引用.还有document.links/document.forms/document.images等 2  document.URL       返回当前文档的url 3  document.title       返回当前文档的标题 4  do

  • JavaScript中windows.open()、windows.close()方法详解

    windows.open()方法详解: window.open(URL,name,features,replace)用于载入指定的URL到新的或已存在的窗口中,并返回代表新窗口的Window对象.它有4个可选的 参数: URL:一个可选的字符串,声明了要在新窗口中显示的文档的 URL.如果省略了这个参数,或者它的值是空字符串,那么新窗口就不会显示任何文档. name:一个可选的字符串,该字符串是一个由逗号分隔的特征列表,其中包括数字.字母和下划线,该字符声明了新窗口的名称.这个名称可以用作标记

  • 基于JavaScript中字符串的match与replace方法(详解)

    1.match方法 match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配. match()方法的返回值为:存放匹配结果的数组. 2.replace方法 replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串. replace方法的返回值为:一个新的字符串. 3.说明 以上2个方法的参数在使用正则表达式时主要添加全局g,这样才能对字符串进行全部匹配或者替换. 示例代码: <!DOCTYPE html> <html lang

随机推荐