国内最全IT社区平台 联系我们 | 收藏本站
华晨云阿里云优惠2
您当前位置:首页 > php开源 > 综合技术 > [React Native]获取网络状态

[React Native]获取网络状态

来源:程序员人生   发布时间:2016-09-27 08:59:18 阅读次数:3484次

使用React Native,可使用NetInfo API获得手机当前的各个网络状态。

componentWillMount() { NetInfo.fetch().done((status)=> { console.log('Status:'+status); }); }

获得网络状态是异步的,上面使用了Promise机制。

Android端网络状态

要求网络信息需要先在利用的AndroidManifest.xml文件中添加以下权限字段,申请相干权限:

<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

这里写图片描述

修改完成后,reaload代码是无效的,由于我们修改了Android原生的配置文件,需要重新履行react-native run-android命令。这个命令重新编译对应的Android项目安装包并安装得手机中。

Android可获得的状态比较多,上面的status可能有以下的值,直接把文档贴出来了:
+ NONE - 装备处于离线状态
+ BLUETOOTH - 蓝牙数据连接
+ DUMMY - 摹拟数据连接
+ ETHERNET - 以太网数据连接
+ MOBILE - 移动网络数据连接
+ MOBILE_DUN - 拨号移动网络数据连接
+ MOBILE_HIPRI - 高优先级移动网络数据连接
+ MOBILE_MMS - 彩信移动网络数据连接
+ MOBILE_SUPL - 安全用户面定位(SUPL)数据连接
+ VPN - 虚拟网络连接。需要Android5.0以上
+ WIFI - WIFI数据连接
+ WIMAX - WiMAX数据连接
+ UNKNOWN - 未知数据连接

IOS端网络状态

  • none - 装备处于离线状态。
  • wifi - 装备处于联网状态且通过wifi链接,或是1个iOS的摹拟器。
  • cell - 装备是通过Edge、3G、WiMax或是LTE网络联网的。
  • unknown - 产生毛病,网络状态不可知

监听网络改变事件

在获得了网络状态后,开发者还可以通过NetInfo API提供的监听器,监听网络状态改变事件。这样当手机网络状态改变时,React Native利用马上收到通知。

componentWillMount() { NetInfo.fetch().done((status)=> { console.log('Status:' + status); }); //监听网络状态改变 NetInfo.addEventListener('change', this.handleConnectivityChange); } componentWillUnMount() { console.log("componentWillUnMount"); NetInfo.removeEventListener('change', this.handleConnectivityChange); } handleConnectivityChange(status) { console.log('status change:' + status); //监听第1次改变后, 可以取消监听.或在componentUnmount中取消监听 // NetInfo.removeEventListener('change', this.handleConnectivityChange); }

判断是不是有网络连接

NetInfo API 为开发者提供了isConnected函数用来判断当前手机是不是有网络连接。

NetInfo.isConnected.fetch().done((isConnected) => { console.log('First, is ' + (isConnected ? 'online' : 'offline')); });

isConnectionExpensive(仅Android端)

NetInfo API为开发者提供了 isConnectionExpensive函数用来判断当前网络连接是不是付费的。如果当前连接是通过移动数据网络,或通过基于移动数据网络所创建的wifi热门,都有可能被判定为计费的数据连接。目前这个函数只为Android平台提供。

NetInfo.isConnectionExpensive((isConnectionExpensive) => { console.log('Connection is ' + (isConnectionExpensive ? 'Expensive' : 'Not Expensive')); });

更多精彩请关注微信公众账号likeDev
这里写图片描述

生活不易,码农辛苦
如果您觉得本网站对您的学习有所帮助,可以手机扫描二维码进行捐赠
程序员人生
------分隔线----------------------------
分享到:
------分隔线----------------------------
关闭
程序员人生