使用js事件机制进行通用操作&特定业务处理的协调
背景:提供一个通用的功能工具条,工具条会在特定的事件响应时进行一些通用处理;第三方系统使用iframe嵌入这个工具条中,在工具条的特定的事件响应时进行通用处理的时候,有可能第三方系统会有一些自己的业务逻辑需要同时处理。
方案1:判断工具条中嵌套的第三方系统是否存在某个对象&方法,判断如果存在,则进行调用。
//....其他代码
try {
thirdWebObj = window.frames["mainFrame"].$.thirdWebObj;
if (thirdWebObj && thirdWebObj.theFunction)//第三方系统调用
thirdWebObj.theFunction(param1,param2);
} catch (e) {
}
缺点:代码耦合性太强,需要工具条和第三方系统对自定义的处理业务的对象和方法名硬性匹配上,灵活性太差。
方案2:后来想到在父平台(指的是工具条)中定义一个数组,用于存储对应的在第三方系统中实现的需要在父平台响应特定事件的时候同步调用的方法名称字符串,然后由第三方系统进行注册,也就是将个性化要调用的方法名称传入父平台的一个初始化方法中。(如果有多个特定响应事件,可以将数组进一步处理,将各个方法名称字符串分类做好标记),然后再使用方案1的判断逻辑进行判断后调用,这个简单验证没有问题,提高了一点,不用父子系统进行强关联。
方案3:之后,同事提醒用事件的方式来处理。
在父平台中定义工具条特定需要处理的对象,以及对象中涉及到的几个事件&方法
var SpecialTb = {};
SpecialTb.Event = $({});
(function(){
SpecialTb.specialTbEvent = new specialTbEvent();
function specialTbEvent(){
var publicObj = this;
//事件类型定义
publicObj.EventType = {
e1 : "e1",
e2 : "e2"
};
//事件绑定功能
publicObj.bindEvent = function(eventName, func){
SpecialTb.Event.unbind(eventName);//移除之前绑定的事件
SpecialTb.Event.bind(eventName, func);
}; //事件触发功能
publicObj.fireEvent = function(eventName, params){
SpecialTb.Event.trigger(eventName, params);
};
} })();
在第三方系统,在需要进行自定义业务处理的地方进行如下调用:
function eventTest() {
if (parent.SpecialTb) {
var parentObj = parent.SpecialTb;
//第三方绑定事件
parentObj.specialTbEvent.bindEvent(parentObj.specialTbEvent.EventType.e1, function (event, obj) {
//第三方事件处理实现
console.log("demo-e1:" + obj.name);
});
parentObj.specialTbEvent.bindEvent(parentObj.specialTbEvent.EventType.e2, function (event, obj) {
console.log("demo-e2:" + obj.name);
});
}
}
这样之后,在父平台的事件响应时的通用处理中增加如下处理,即可完成第三方系统的特定处理内容的执行。
//SpecialTb触发事件,传递参数时传递json对象,这里单独以e1这个事件为例
SpecialTb.specialTbEvent.fireEvent(SpecialTb.specialTbEvent.EventType.e1,[{
name:"myName"
}]);
这样做的好处是,父平台和第三方系统之前的依赖关系彻底解耦,只需要约定好事件名称以及事件响应方法涉及到的参数即可各自完成开发。
使用js事件机制进行通用操作&特定业务处理的协调的更多相关文章
- node.js零基础详细教程(4):node.js事件机制、node异步IO操作
第四章 建议学习时间3小时 课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...
- js事件机制
js事件属性:
- 对JS事件机制的深入理解
一.发生一个事件时,事件及事件处理程序会被放入浏览器的事件队列,事件可归为以下几类: 浏览器事件:window.load.document.DomContentLoaded等 网络请求事件:ajax. ...
- js事件机制——事件冒泡和捕获
概念:当给子元素和父元素定义了相同的事件,比如都定义了onclick事件,点击子元素时,父元素的onclick事件也会被触发.js里称这种事件连续发生的机制为事件冒泡或者事件捕获. IE浏览器:事件从 ...
- js事件浅析
js中关于DOM的操作很多,因此js事件机制也就尤为重要. 事件绑定形式: 一. 内联形式 耦合度高,不利于维护 <button onclick="alert('你点击了这个按钮'); ...
- JavaScript 详说事件机制之冒泡、捕获、传播、委托
DOM事件流(event flow )存在三个阶段:事件捕获阶段.处于目标阶段.事件冒泡阶段. 事件捕获(event capturing):通俗的理解就是,当鼠标点击或者触发dom事件时,浏览器会 ...
- Node.js 事件循环(Event Loop)介绍
Node.js 事件循环(Event Loop)介绍 JavaScript是一种单线程运行但又绝不会阻塞的语言,其实现非阻塞的关键是“事件循环”和“回调机制”.Node.js在JavaScript的基 ...
- JS执行机制详解,定时器时间间隔的真正含义
壹 ❀ 引 通过结果倒推过程是我们常用的思考模式,我在上一篇学习promise笔记中,有少量关于promise执行顺序的例子,通过倒推,我成功让自己对于js执行机制的理解一塌糊涂,js事件机制,事件 ...
- Ext JS学习第十六天 事件机制event(一) DotNet进阶系列(持续更新) 第一节:.Net版基于WebSocket的聊天室样例 第十五节:深入理解async和await的作用及各种适用场景和用法 第十五节:深入理解async和await的作用及各种适用场景和用法 前端自动化准备和详细配置(NVM、NPM/CNPM、NodeJs、NRM、WebPack、Gulp/Grunt、G
code&monkey Ext JS学习第十六天 事件机制event(一) 此文用来记录学习笔记: 休息了好几天,从今天开始继续保持更新,鞭策自己学习 今天我们来说一说什么是事件,对于事件 ...
随机推荐
- Mac怎样改动开机password
Mac开机password忘了,咋办?开不开机啦 1.打开你的Mac,command +S 进入你的终端界面 2.输入/sbin/mount -uaw / 3.输入rm /var/db/.AppleS ...
- 符号三角形_hdu_2510(深搜).java
http://acm.hdu.edu.cn/showproblem.php?pid=2510 Time Limit: 2000/1000 MS (Java/Others) Memory Limi ...
- 算法笔记_157:算法提高 c++_ch02_01(Java)
目录 1 问题描述 2 解决方案 1 问题描述 编写一个程序,利用强制类型转换打印元音字母大小写10种形式的ASCII码. 输出的顺序为:大写的字母A,E,I,O,U的ASCII码,小写的字母a, ...
- 关于Csdn水区被占据一事 (2015-08-01)
例如以下图所看到的 水区被占据 ,假设发贴机不仅仅在水区发贴.也在其他版块也发贴,将不堪设想啊各位. 如今非常多站点也经历过被 注冊机,发贴机,乱炸,是非常可恨的事.可是您想想.为什么注冊机.发贴机会 ...
- mmap 函数
头文件:#include <unistd.h> #include <sys/mman.h> 定义函数:void *mmap(void *start, size_t len ...
- js 实现图片的无缝滚动
js 实现图片的无缝滚动 CreateTime--2018年3月7日17:18:34 Author:Marydon 测试成功 <!DOCTYPE html> <html> ...
- Web.config中设置启用webservice远程调试訪问
在.NET 中已经默认将webservice的远程调试功能关闭.有的时候我们须要远程调试程序的时候,就须要打开此功能我们仅仅需在webservice的项目的中添web.config的<syste ...
- gdb调试运行程序带参数(调用动态链接库),debug过程记录
library多线程file1.gdb (运行程序名称) 例如 gdb cbenchmark 2.设置运行参数 set args -c 1 -n 1 -F ./libaliww.so -l 1 3.如 ...
- Ubuntu开机自动禁用无线网络
让ubuntu开机自动禁用无线网络. 1.自启动脚本 将下面这条禁用无线网络的命令添加到“启动应用程序“中,这样开机时无线网络就会被自动禁用. dbus-send --system --type=me ...
- 构造函数、析构函数、赋值与初始化、explicit关键字
一.构造函数.默认构造函数 (1).构造函数 构造函数是特殊的成员函数 创建类类型的新对象,系统自动会调用构造函数 构造函数是为了保证对象的每个数据成员都被正确初始化 函数名和类名完全相同 不能定义构 ...