现在,组件化开发还是比较流行的,毕竟其优点相当突出。最近在开发一个组件的时候,遇到了一个很有意思的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
# 回调
# 自定义
# 多个
# 给大家
# 如果没有
# 的是
# 是一个
# 给我
# 页面内
# 好了
# 还可以
# 发出了
# 遍历
# 两次
# 能在
# 就没
# 用了
# 希望能
# 这个时候
# 只有一个
相关文章:
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
深入理解Android中的xmlns:tools属性
如何制作一个表白网站视频,关于勇敢表白的小标题?
安云自助建站系统如何快速提升SEO排名?
如何快速搭建高效WAP手机网站吸引移动用户?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?
制作充值网站的软件,做人力招聘为什么要自己交端口钱?
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
建站之星各版本价格是多少?
公司网站制作价格怎么算,公司办个官网需要多少钱?
网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?
建站主机系统SEO优化与智能配置核心关键词操作指南
网站制作价目表怎么做,珍爱网婚介费用多少?
岳西云建站教程与模板下载_一站式快速建站系统操作指南
阿里云网站制作公司,阿里云快速搭建网站好用吗?
5种Android数据存储方式汇总
购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?
广州顶尖建站服务:企业官网建设与SEO优化一体化方案
广州商城建站系统开发成本与周期如何控制?
公司门户网站制作流程,华为官网怎么做?
如何快速生成高效建站系统源代码?
建站之星导航配置指南:自助建站与SEO优化全解析
如何在阿里云ECS服务器部署织梦CMS网站?
如何用PHP快速搭建高效网站?分步指南
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
实惠建站价格推荐:2025年高性价比自助建站套餐解析
如何用y主机助手快速搭建网站?
如何选择靠谱的建站公司加盟品牌?
简历在线制作网站免费版,如何创建个人简历?
中山网站推广排名,中山信息港登录入口?
创业网站制作流程,创业网站可靠吗?
Swift中switch语句区间和元组模式匹配
网站制作公司排行榜,抖音怎样做个人官方网站
香港服务器WordPress建站指南:SEO优化与高效部署策略
导航网站建站方案与优化指南:一站式高效搭建技巧解析
如何规划企业建站流程的关键步骤?
义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?
制作农业网站的软件,比较好的农业网站推荐一下?
免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?
南平网站制作公司,2025年南平市事业单位报名时间?
上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?
,柠檬视频怎样兑换vip?
如何通过西部建站助手安装IIS服务器?
西安大型网站制作公司,西安招聘网站最好的是哪个?
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
招贴海报怎么做,什么是海报招贴?
深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?
如何通过建站之星自助学习解决操作问题?
深圳企业网站制作设计,在深圳如何网上全流程注册公司?
*请认真填写需求信息,我们会在24小时内与您取得联系。