234 lines
		
	
	
		
			21 KiB
		
	
	
	
		
			Vue
		
	
	
	
		
		
			
		
	
	
			234 lines
		
	
	
		
			21 KiB
		
	
	
	
		
			Vue
		
	
	
	
| 
								 | 
							
								<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>
							 |