使用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(一) 此文用来记录学习笔记: 休息了好几天,从今天开始继续保持更新,鞭策自己学习 今天我们来说一说什么是事件,对于事件 ...
随机推荐
- [Algorithm] Array production problem
Given an array of integers, return a new array such that each element at index i of the new array is ...
- Eclipse自动编译NDK/JNI的三种方法
一.Eclipse关联cygwin 1. 工程->右击选择Properties->选择Builders,在Builders中选择New创建一个Program 2. 参数配置 二.Eclip ...
- Java网络编程-HTTP协议
HTTP协议的定义 这篇文章暂时不研究HTTP底层的TCP/IP的握手和挥手过程,只从表面的交互流程分析HTTP协议. HTTP英文全称是Hypertext Transfer Protpcol,也就是 ...
- CLightLock:一个简单AutoLock
原理: 标准的RAII, 利用构造函数进行加锁,利用析构函数进行解锁. #ifndef _C_LIGTHT_LOCK_HPP #define _C_LIGTHT_LOCK_HPP class CLig ...
- JDBC JdbcUtils( 本博多次出现的简陋工具类)
package test; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; ...
- Linux ext2/ext3文件系统详解
转载: Linux ext2/ext3文件系统使用索引节点来记录文件信息,作用像windows的文件分配表.索引节点是一个结构,它包含了一个文件的长度.创建及修改时间.权限.所属关系.磁盘中的位置等信 ...
- 增强基本选择器[selector_3.html]
增强基本选择器[selector_3.html] $("ul li:first") $("ul li:last") $("table tr:even& ...
- Linux-软件包管理-源码包安装
rpm -q gcc 查看c语言编译器是否已经安装 在浏览器输入:http://mirror.bit.edu.cn/apache/httpd/ 下载2.2.29这个包 cd ~ 回到root目录 ls ...
- 工作总结 Rezor 里面的一些小知识----自定义类型 放在标签值中 会直接跳过去
0 的时候不报错 1 的时候 报错了 原因 是 imagesname[i] 索引超出了 为什么在 上面 报错呢? 不在这里报错呢? 说明了 Rezor 对于 自定义的变量 放在标签值里的时候,调 ...
- 又是一年WWDC,暨回想去年之旅——Part III
前言 无论这篇写到哪里,就以这篇作为结尾,结束这个流水回想系列文了. Computer History Museum 计算机历史博物馆(站点)是在Google旁边,參观Google之前的行程. 记得那 ...