uniapp--微信小程序无网络提示组件页面

uniapp–微信小程序无网络提示组件页面

1.组件页面fu-notwork.vue代码

<template>
	<view class="fu-notwork" v-if="!isConnected">
		<view class="fu-count-df" v-if="mode == 'full'" :style="{ zIndex: zIndex }">
			<image class="icon" :src="image" mode="aspectFit"></image>
			<view class="tips">{{ tips }}</view>
			<view class="text-gray text-sm margin-bottom-sm">
				{{ i18n['请检查网络,或者前往'] }}
				<text class="text-blue">{{ i18n['设置'] }}</text>
			</view>
			<view @click="getNetworkStattus">{{ i18n['点击刷新'] }}</view>
		</view>
		<view class="fu-count-tips" v-if="mode == 'tips'">
			<text></text>
			<text>{{ tips }}</text>
		</view>
	</view>
</template>

<script>
	/**
	 * fu-notwork 无网络提示
	 * @description 该组件无需任何配置,引入即可,内部自动处理所有功能和事件。
	 * @property {String} mode full 全屏模式 | tips 占位模式 | toast 提示框模式 | modal 弹框模式
	 * @property {String} tips 没有网络时的提示语(默认哎呀,网络信号丢失)
	 * @property {String Number} zIndex 组件的z-index值(默认1080)
	 * @property {String} image 无网络的图片提示,可用的src地址或base64图片
	 * @event {Function} retry 用户点击页面的"重试"按钮时触发
	 * @example <fu-notwork></fu-notwork>
	 */
	export default {
		name: 'fu-notwork',
		props: {
			// 组件模式 默认全屏模式 、tips 占位模式 、toast 提示框模式
			mode: {
				type: String,
				default () {
					return 'full';
				}
			},
			tips: {
				type: String,
				default () {
					return global.i18n['哎呀,网络信号丢失'];
				}
			},

			zIndex: {
				type: [String, Number],
				default () {
					return 100;
				}
			},

			image: {
				type: String,
				default () {
					return '';
				}
			}
		},
		data() {
			return {
				isConnected: true
			};
		},
		created() {
			let _this = this;
			uni.getSystemInfo({
				success: (res) => {
					console.log(res.platform, 'platformplatform')
					_this.platform = res.platform;
				}
			})
			// 监听网络状态的变化
			uni.onNetworkStatusChange(res => {
				// console.log(res)
				this.isConnected = res.isConnected;
				if (this.isConnected) {
					if (!uni.getStorageSync('CommonNetConnected') && _this.platform == 'ios') {
						uni.setStorageSync('CommonNetConnected', true)
						setTimeout(() => {
							plus.runtime.restart()
						}, 1000)
					} else {
						uni.setStorageSync('CommonNetConnected', true)
					}
					this.$emit('retry', {
						msg: this.i18n['网络链接成功'],
						networkType: res.networkType
					});
				} else {
					if (this.mode == 'toast') {
						this.$message.info(this.tips);
					}
				}
			});
			this.getNetworkStattus();
		},
		methods: {
			// 功能:获取当前网络状态
			getNetworkStattus() {
				uni.getNetworkType({
					success: res => {
						// console.log(res.networkType);
						if (res.networkType == 'none') {
							this.isConnected = false;

							switch (this.mode) {
			 				case 'modal':
									this.$util.showModal({
										title: '提示',
										content: this.tips
			  				});
									break;
								case 'toast':
									this.$message.info(this.tips);
									break;
								default:
									this.$message.info({
										content: this.i18n['无网络链接'],
										position: 'top'
									});
									break;
							}
						} else {
							this.isConnected = true;
							if (!uni.getStorageSync('CommonNetConnected')) {
								uni.setStorageSync('CommonNetConnected', true)
								setTimeout(() => {
									plus.runtime.restart()
								}, 1000)
							}
							this.$emit('retry', {
								msg: this.i18n['网络链接成功'],
								networkType: res.networkType
							});
						}
					}
				});
			}
		}
	};
</script>

<style lang="scss">
//在uni.scss中定义 $fu-prefix: fu;
	.#{$fu-prefix} {
		&-notwork {
			color: #666;

			.#{$fu-prefix}-count-df {
				position: fixed;
				top: 0;
				left: 0;
				width: 100%;
				height: 100%;
				background-color: white;
				text-align: center;
				padding-top: 380rpx;
				z-index: 9999;

				.icon {
					width: 200rpx;
					height: 200rpx;
					margin-bottom: 20rpx;
				}

				.tips {
					margin-bottom: 20rpx;
				}
			}

			.#{$fu-prefix}-count-tips {
				font-size: 24rpx;
				line-height: 80rpx;
				background-color: #ffdfdf;
				color: #666;
				text-align: center;
			}
		}
	}
</style>

2.全局引用

  <!-- 断网检测 start -->
    <fu-notwork></fu-notwork>
  <!-- 断网检测 end -->
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值