当前位置: 首页 > news >正文

个人网站模板html优化是企业通过网站来做吗

个人网站模板html,优化是企业通过网站来做吗,做付费软件网站,辽宁省建设厅官方网站职称评定前言 在真实的项目中,我们为了良好的用户体验,会根据用户当前的网络状态提供最优的资源,例如图片或视频等比较大的资源,当网络较差时,可以提供分辨率更低的资源,能够让用户尽可能快的看到有效信息&#xf…

前言

在真实的项目中,我们为了良好的用户体验,会根据用户当前的网络状态提供最优的资源,例如图片或视频等比较大的资源,当网络较差时,可以提供分辨率更低的资源,能够让用户尽可能快的看到有效信息,而不是一直白屏等待。

那如何设计一个生产环境可用的小程序当前网络状态监测系统。主要考虑以下几个方面:

  • 首先我们可以粗略的用getNetworkType来获取当前的网络连接类型,当获取到2g或3g等类型时,可以判定当前处于弱网状态。
  • 当处于4g,5g或wifi下,我们的网络也是会有波动的,这个时候就需要我们根据真实的网络下载情况来判断网络状态,
  • 当判断处于弱网时,这个时候我们要持续的来获取当前网络状况,当网络状况好转或设置一个最长检测的时间,当规定时间内,网络依然没有好转,则停止获取网络状况。
  • 通过全局的eventBus系统,将网络状态发射出去,供业务功能处使用。

实现

细节步骤

  • 划定网络的判定标准,也就是什么情况处于弱网,什么时候处于好的网络。

    • 网络类型上2g和3g直接判定为弱网
    • 通过真实请求一张图片,来实际获取当前的网络请求状况,可以有两种方式:
      • 一种是通过耗时,这里选择一个阈值范围1000, 1500,低于1000的为极好网,中间的为好网,超过1500则为
      • 一种是通过,request/download接口回调中提供的profile信息,其中throughputKbps表示当前网络的实际下载kbps。
  • 判断弱网后的处理。判断弱网后,我们不能就直接让我们的资源加载都处于一种弱网的情况,而是判断弱网后,我们要递归的去持续判断网络状态,直至网络状况好转,或有一个最大的重试次数,很长一段时间网络状态都不好,就不用在尝试去判断了,用户也不可能一直在这等待网络好转。

  • 持续监控。也就是判断网络的时机:

    • 一种是监听网络类型的切换,通过wx.onNetworkStatusChange。网络类型切换时,进行网络判断
    • 每一次接口请求的时候,都进行一次网络状态判断,因此,这里我们要封装一个自己的request方法,将通用的逻辑都封装在一处。

代码展示

js

// import eventBus from './eventBus';
const NETWORK_STATUS = {OFFLINE: 'offline',POOR: 'poor',GOOD: 'good',WONDERFUL: 'wonderful'
}
// 小于1000表示网络极好,1000至1500则表示good 超过1500表明是弱网。
const DOWNLOAD_TIME = [1000, 1500];
const MAX_COUNT = 10;
let count = 0;
function getNetworkType() {return new Promise((resolve) => {wx.getNetworkType({success(res) {resolve(res);},fail(err) {resolve(err);}})})
}
const getNetworkStatus =  (opt) => {return new Promise((resolve) => {try {let networkType = opt && opt.networkType;let networkStatus = NETWORK_STATUS.WONDERFUL;if (!networkType) {networkType = getNetworkType().then(({networkType}) => {if (['unknown', 'none'].includes(networkType)) {emitNetworkStatus(NETWORK_STATUS.OFFLINE);return resolve(NETWORK_STATUS.OFFLINE);}if (['2g', '3g'].includes(networkType)) {emitNetworkStatus(NETWORK_STATUS.POOR);return resolve(NETWORK_STATUS);}const startTime = +new Date();requestImage().then((result) => {const requestTime = +new Date() - startTime;if (requestTime < DOWNLOAD_TIME[0]) {networkStatus = NETWORK_STATUS.WONDERFUL;} else if (requestTime > DOWNLOAD_TIME[1]) {networkStatus = NETWORK_STATUS.POOR;} else {networkStatus = NETWORK_STATUS.GOOD;}emitNetworkStatus(networkStatus);return resolve(networkStatus);})});}} catch (error) {resolve(NETWORK_STATUS.WONDERFUL);}})}function run() {if (count >= MAX_COUNT) {return;}const timer = setTimeout( () => {getNetworkStatus().then(networkStatus => {count += 1;if ([NETWORK_STATUS.POOR, NETWORK_STATUS.GOOD].includes(networkStatus)){run();}})clearTimeout(timer);}, 5000)
}
function start(opt) {const timer = setTimeout( () => {getNetworkStatus(opt).then(networkStatus => {if ([NETWORK_STATUS.POOR, NETWORK_STATUS.GOOD].includes(networkStatus)) {run();}})clearTimeout(timer);}, 1000)
}
function requestImage() {return new Promise((resolve) => {wx.request({url: 'https://dss0.bdstatic.com/-0U0bnSm1A5BphGlnYG/tam-ogel/-146383143_-1016538910_80_80.png',data: {time: +new Date(),},success(res) {resolve(res);},fail() {resolve()}})})
}
function emitNetworkStatus(networkStatus) {const app = getApp();const oldNetwordStatus  = app.globalData.networkStatus;// 只有本次状态与上一次存储的不一致才会对外发送。if (oldNetwordStatus !== networkStatus) {app.globalData.networkStatus = networkStatus;// 通过全局的事件系统,将结果发送出去// eventBus.emit('networkChange', networkStatus, oldNetwordStatus);    }
}export const networkController = {start,
};

eventBus功能可以根据自己的项目自行封装,这里不再多述。

调用时机

  • app.js中的onLaunch钩子中,监听wx.onNetworkStatusChange。在其中调用我们的方法

js

 wx.onNetworkStatusChange((res) => {networkController.start(res);})
  • 另一种就是在我们封装的request函数内,每次请求接口时调用一次。这样能够保证我们可以不那么频繁但有效的去判断是否去判断当前网络状态

总结

作为一个c端产品,针对弱网的优化是必不可少的。用户体验问题要一直放在最重要的位置,作为开发人员要时刻关注这些点,以免给用户造成不好的体验。

如果有更好的意见,辛苦评论区指出,共同学习,共同提高。

http://www.yayakq.cn/news/486193/

相关文章:

  • 无锡高端网站设计程建网
  • 网站开发 名片石家庄房价
  • 网站网站制作网站的台州国强建设网站
  • 苏宁易购网站建设 的定位广东网站建设微信商城开发
  • 网站建设服务公司专业服务黔西南网站建设
  • dede网站收录廊坊网站建站网站
  • wordpress安装 用户名已存在哪里福州seo推广公司
  • 免费试用网站制作网络的推广
  • 国税网站建设调查报告51zwd一起做网店
  • 高端网站建设谷美智慧团建网站入口手机版
  • 做前端常用的网站及软件php做简单网站教程视频教程
  • 成品网站免费下载个人注册运输公司流程和费用
  • wordpress站演示公司的研究与开发
  • 海外海外网站建设品牌设计包括哪些方面
  • 做网站推广的销售发的朋友圈江苏网站建设制作
  • 番禺微网站建设网站的备案号查询
  • 石狮市住房和城乡建设局网站网站推广公司官网
  • 雍鑫建设集团网站网页设计电子版教材
  • 龙岗网站建设费用平面设计与网页设计
  • 简述网站开发建设的基本流程昆山公司网站建设电话
  • 长沙免费网站排名有哪些可以做兼职的翻译网站吗
  • 网站建设的目标是什么 提供了哪些栏目想卖产品怎么推广宣传
  • 电商网站首页字体温州网站开发app制作
  • 建立网站邮箱附近男科医院在哪里
  • 申请一个网站需要怎么做wordpress meta slider
  • 网站开发实验报告三购买域名后用wordpress建站
  • 企业网站设计服务公司高水平的大连网站建设
  • 特产网站建设策划书微信小程序开发实战课后答案
  • 长沙门户网站上海短期网站建设培训
  • photoshop网站模板设计教程视频凡科快速建站