|
|
<template> <view class="u-no-network" v-if="!isConnected" :style="{'z-index': uZIndex}" @touchmove.stop.prevent="() => {}"> <view class="u-inner"> <image class="u-error-icon" :src="image" mode="widthFix"></image> <view class="u-tips"> {{tips}} </view> <!-- 只有APP平台,才能跳转设置页,因为需要调用plus环境 --> <!-- #ifdef APP-PLUS --> <view class="u-to-setting"> 请检查网络,或前往<text class="u-setting-btn" @tap="openSettings">设置</text> </view> <!-- #endif --> <view class="u-retry" :hover-stay-time="150" @tap="retry" hover-class="u-retry-hover"> 重试 </view> </view> </view> </template>
<script> /** * noNetwork 无网络提示 * @description 该组件无需任何配置,引入即可,内部自动处理所有功能和事件。 * @tutorial https://www.uviewui.com/components/noNetwork.html
* @property {String} tips 没有网络时的提示语(默认哎呀,网络信号丢失) * @property {String Number} zIndex 组件的z-index值(默认1080) * @property {String} image 无网络的图片提示,可用的src地址或base64图片 * @event {Function} retry 用户点击页面的"重试"按钮时触发 * @example <u-no-network></u-no-network> */ export default { name: "u-no-network", props: { // 页面文字提示
tips: { type: String, default: '哎呀,网络信号丢失' }, // 一个z-index值,用于设置没有网络这个组件的层次,因为页面可能会有其他定位的元素层级过高,导致此组件被覆盖
zIndex: { type: [Number, String], default: '' }, // image 没有网络的图片提示
image: { type: String, default: " } }, data() { return { isConnected: true, // 是否有网络连接
networkType: "none", // 网络类型
} }, computed: { uZIndex() { return this.zIndex ? this.zIndex : this.$u.zIndex.noNetwork; } }, mounted() { this.isIOS = (uni.getSystemInfoSync().platform === 'ios'); uni.onNetworkStatusChange((res) => { this.isConnected = res.isConnected; this.networkType = res.networkType; }); uni.getNetworkType({ success: (res) => { this.networkType = res.networkType; if (res.networkType == 'none') { this.isConnected = false; } else { this.isConnected = true; } } }); }, methods: { retry() { // 重新检查网络
uni.getNetworkType({ success: (res) => { this.networkType = res.networkType; if (res.networkType == 'none') { uni.showToast({ title: '无网络连接', icon: 'none', position: 'top' }) this.isConnected = false; } else { uni.showToast({ title: '网络已连接', icon: 'none', position: 'top' }) this.isConnected = true; } } }); this.$emit('retry'); }, async openSettings() { if (this.networkType == "none") { this.openSystemSettings(); return; } }, openAppSettings() { this.gotoAppSetting(); }, openSystemSettings() { // 以下方法来自5+范畴,如需深究,请自行查阅相关文档
// https://ask.dcloud.net.cn/docs/
if (this.isIOS) { this.gotoiOSSetting(); } else { this.gotoAndroidSetting(); } }, network() { var result = null; var cellularData = plus.ios.newObject("CTCellularData"); var state = cellularData.plusGetAttribute("restrictedState"); if (state == 0) { result = null; } else if (state == 2) { result = 1; } else if (state == 1) { result = 2; } plus.ios.deleteObject(cellularData); return result; }, gotoAppSetting() { if (this.isIOS) { var UIApplication = plus.ios.import("UIApplication"); var application2 = UIApplication.sharedApplication(); var NSURL2 = plus.ios.import("NSURL"); var setting2 = NSURL2.URLWithString("app-settings:"); application2.openURL(setting2); plus.ios.deleteObject(setting2); plus.ios.deleteObject(NSURL2); plus.ios.deleteObject(application2); } else { var Intent = plus.android.importClass("android.content.Intent"); var Settings = plus.android.importClass("android.provider.Settings"); var Uri = plus.android.importClass("android.net.Uri"); var mainActivity = plus.android.runtimeMainActivity(); var intent = new Intent(); intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS); var uri = Uri.fromParts("package", mainActivity.getPackageName(), null); intent.setData(uri); mainActivity.startActivity(intent); } }, gotoiOSSetting() { var UIApplication = plus.ios.import("UIApplication"); var application2 = UIApplication.sharedApplication(); var NSURL2 = plus.ios.import("NSURL"); var setting2 = NSURL2.URLWithString("App-prefs:root=General"); application2.openURL(setting2); plus.ios.deleteObject(setting2); plus.ios.deleteObject(NSURL2); plus.ios.deleteObject(application2); }, gotoAndroidSetting() { var Intent = plus.android.importClass("android.content.Intent"); var Settings = plus.android.importClass("android.provider.Settings"); var mainActivity = plus.android.runtimeMainActivity(); var intent = new Intent(Settings.ACTION_SETTINGS); mainActivity.startActivity(intent); } } } </script>
<style lang="scss" scoped> @import "../../libs/css/style.components.scss"; .u-no-network { background-color: #fff; position: fixed; top: 0; left: 0; right: 0; bottom: 0; }
.u-inner { height: 100vh; @include vue-flex; flex-direction: column; align-items: center; justify-content: center; margin-top: -15%; }
.u-tips { color: $u-tips-color; font-size: 28rpx; padding: 30rpx 0; }
.u-error-icon { width: 300rpx; }
.u-to-setting { color: $u-light-color; font-size: 26rpx; }
.u-setting-btn { font-size: 26rpx; color: $u-type-primary; }
.u-retry { margin-top: 30rpx; border: 1px solid $u-tips-color; color: $u-tips-color; font-size: 28rpx; padding: 6rpx 30rpx; border-radius: 3px; }
.u-retry-hover { color: #fff; background-color: $u-tips-color; } </style>
|