全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

自定义事件解决重复请求BUG的问题

现在,组件化开发还是比较流行的,毕竟其优点相当突出。最近在开发一个组件的时候,遇到了一个很有意思的BUG。。。

BUG的背景

最近在开发一个组件,好不容易开发好了转测试。然后,测试给我提了一个这样的bug,orz...

因为是一个组件,最大的好处就是可以随处复用,随处使用,然而,当一个页面用了多个组件,只有最后一个生效的时候,这个组件就没有什么意义了。。。

BUG原因查找

这个组件的初始数据来源的接口是固定的,也就是说,页面内的所有这个组件在初始化的时候都会发出同样的请求,这里的请求是jsonp的方式,所以回调函数是绑定在window上的一个函数,但是在页面中window只有一个,所以在回调处理的时候,要处理的组件内的相应的数据只指向最后一个组件。所以导致多个同样的组件在同一个页面中,只有最后一个组件能在取得数据之后顺利渲染出来。

BUG解决思路

最主要就是要将每次请求的callback存储起来,这样就可以保证callback中对组件数据的处理不是只指向最后一个。其次,既然是一样的请求,当然不希望会发出两次以上啦,即一个页面发出的每一个请求都是唯一的。

BUG解决方案

想到了发布订阅者模式的自定义事件,可以写这样的一个模块,每次请求发出前判断一下之前是否有相同的模块已经发出了,如果没有则缓存callback发出请求,如果有相同的请求已经发出了,那么检查一下这个发出的请求是否已经完成了,如果没有则继续缓存callback等待,如果请求已经发出并且已经完成则直接处理callback。在请求第一次回来后,发出广播,把之前缓存的callback都执行一次。

自定义事件详情

定义一个模块,里面有n个以回调函数命名的事件对象,每个对象有在被初始化的时候,定义其状态state,对应的callback数组,请求回到的数据data。每次调用该模块,首先检查对应的cbName是否被初始化,然后检查其state。根据state做相应的操作并改变state的值。state的值有3中,分别为init、loading、loaded。即初始化、请求中、请求完成。处于请求完成状态时才能执行相应的回调。

具体如下:

define('wq.getData', function (require, exports, module) {
  var ls = require('loadJs');
   
  var cache = {};
  cache.init = function(cb,cbName,url){
    if(!cache[cbName]){
      cache[cbName] = {};
      cache[cbName].state = 'init';
      cache[cbName].cbs = [];
      cache[cbName].data = [];
    }
    cache.on(cb,cbName,url);
  }
  cache.on = function(cb,cbName,url){
    if(cache[cbName].state == 'loaded'){
      cb(cache[cbName].data)
    }else if(cache[cbName].state == 'loading'){
      cache[cbName].cbs.push(cb)
    }else if(cache[cbName].state == 'init'){
      cache[cbName].cbs.push(cb);
      cache[cbName].state = 'loading';
      cache.fetch(cb,cbName,url);
    }
  }
  cache.broadcast = function(cbName){
    cache[cbName].cbs.forEach(function(cb){
      cb(cache[cbName].data)
    });
  }
  cache.checkLoaded = function(cbName){
    if(cache[cbName].data[0]){
      cache[cbName].state = 'loaded';
      cache.broadcast(cbName);
    }
  }
  cache.fetch = function(cb,cbName,url){
    ls.loadScript({
      url: url,
      charset: 'utf-8',
      handleError:function(func, args, context,errorObj){
        console.log(_errlogText + context);
        cache[cbName].data[0] = {};
        cache.checkLoaded(cbName);
      }
    });
    if(window.cbName) return;
    window[cbName] = function(json){
      cache[cbName].data[0] = json;
      cache.checkLoaded(cbName);
    }
  }
 
  exports.getData = function(cb,cbName,url){
    cache.init(cb,cbName,url);
  } 
 
})

完美解决问题,每个回调都不会遗漏或者被覆盖……

扩展思路

该模块可通用于处理一个页面内同一个请求的情况。还可以扩展到处理一些需要2个请求以上完成才执行某个回调的情况。类似于Promose的情况。这个时候可以规定,每个data[0]装的是固定的对应接口的数据,data[2]对应另一个,一次类推。不过这样就要遍历到每一项都为true的时候才执行回调。而且对应关系比较容易混乱,再扩展就不如直接用Promise来处理了。。。

以上这篇自定义事件解决重复请求BUG的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


# 自定义事件解决重复请求bug  # 回调  # 自定义  # 多个  # 给大家  # 如果没有  # 的是  # 是一个  # 给我  # 页面内  # 好了  # 还可以  # 发出了  # 遍历  # 两次  # 能在  # 就没  # 用了  # 希望能  # 这个时候  # 只有一个 


相关文章: 公司网站的制作公司,企业网站制作基本流程有哪些?  潮流网站制作头像软件下载,适合母子的网名有哪些?  行程制作网站有哪些,第三方机票电子行程单怎么开?  淘宝制作网站有哪些,淘宝网官网主页?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  韩国服务器如何优化跨境访问实现高效连接?  建站之星×万网:智能建站系统+自助建站平台一键生成  南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  建站之星ASP如何实现CMS高效搭建与安全管理?  c++ stringstream用法详解_c++字符串与数字转换利器  如何用PHP工具快速搭建高效网站?  ,购物网站怎么盈利呢?  建站与域名管理如何高效结合?  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  网站专业制作公司有哪些,做一个公司网站要多少钱?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  零基础网站服务器架设实战:轻量应用与域名解析配置指南  如何快速搭建高效WAP手机网站?  建站之星备案是否影响网站上线时间?  教学网站制作软件,学习*后期制作的网站有哪些?  金*站制作公司有哪些,金华教育集团官网?  建站之星后台密码遗忘如何找回?  家具网站制作软件,家具厂怎么跑业务?  营销式网站制作方案,销售哪个网站招聘效果最好?  如何规划企业建站流程的关键步骤?  如何在万网自助建站中设置域名及备案?  免费公司网站制作软件,如何申请免费主页空间做自己的网站?  如何选择可靠的免备案建站服务器?  网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?  开源网站制作软件,开源网站什么意思?  宝塔新建站点为何无法访问?如何排查?  如何通过远程VPS快速搭建个人网站?  大连网站设计制作招聘信息,大连投诉网站有哪些?  外贸公司网站制作,外贸网站建设一般有哪些步骤?  早安海报制作网站推荐大全,企业早安海报怎么每天更换?  长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?  弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  如何在宝塔面板中修改默认建站目录?  如何基于PHP生成高效IDC网络公司建站源码?  网站网页制作专业公司,怎样制作自己的网页?  个人摄影网站制作流程,摄影爱好者都去什么网站?  制作网页的网站有哪些,电脑上怎么做网页?  制作营销网站公司,淘特是干什么用的?  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  微课制作网站有哪些,微课网怎么进?  香港服务器WordPress建站指南:SEO优化与高效部署策略  网站建设制作、微信公众号,公明人民医院怎么在网上预约?  企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?  免费制作小说封面的网站有哪些,怎么接网站批量的封面单? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。