一个很小的技巧,留下一笔,供日后查看。

业务场景:

一个页面A,打开一个新窗口页面B,执行业务操作,B执行完后,回调A页面方法,并关闭自身。

最原始方法:

最直接的方法莫过于在B页面直接调用A页面的某一个方法,示例代码如下:

A页面打开B页面的方法如下:

 function showIndustry() {
var title = "行业选择";
layer.open({
title: title,
type: ,
area: ['768px', '550px'],
fixed: false, //不固定
maxmin: true,
content: ctxPath + 'sgjXzzfCommon/industryView'
});
}

B页面保存方法如下:

    function saveInfo() {
var a = $("#selectId").val();
var b = $("#selectName").val();
parent.initIndustrySelect(a, b);
closeLayer();
}

这样写完全满足需要,但是如果B页面是一个公共的页面,供很多页面调用的话,那么这种写法就存在如下2个问题:

1.写页面的人很多,不可能把回调函数都命名为相同的方法名称,让B页面回调。这样会增加页面间调用出错的可能性。

2.B页面根据不同的父页面,编写各种if else语句或者switch语句,用来判断应该回调那些页面的函数,增加了代码量和出错的概率。

为此,如果能有一种方法让B根据调用者的意图来回调,又不增加额外的代码,那么简直就是极好的。于是,有了如下的办法:

新方法:

A页面打开B页面时,增加一个参数callbackFun,用于告诉B页面回调函数名称叫什么,然后B页面在完成自身操作后,直接回调这个函数。

 function showIndustry() {
var title = "行业选择";
layer.open({
title: title,
type: ,
area: ['768px', '550px'],
fixed: false, //不固定
maxmin: true,
content: ctxPath + 'sgjXzzfCommon/industryView?callbackFun=initIndustrySelect'
});
}
function initIndustrySelect(obj) {
if (obj!= null) {
currentForm.find("input[name=industry]").first().val(obj.id);
currentForm.find("input[name=industryName]").first().val(obj.name);
}
}

B页面的回调方法如下:

function saveInfo() {
if (currentForm.valid() == false) {
return;
}
$("#btnSubmit").prop("disabled", true);
currentForm.ajaxSubmit({
type: 'post',
url: ctxPath + "sgjXzzfCommon/add",
success: function (data) {
$("#btnSubmit").prop("disabled", false);
if (data.success == true) {
callback(data.data);
closeLayer("保存成功");
}
else {
layer.alert("提交失败:" + data.error);
}
},
error: function (data) {
$("#btnSubmit").prop("disabled", false);
layer.alert("提交失败:" + data.statusText);
}
});
}
 function callback(obj) {
var fun = /*[[${callbackFun}]]*/;
if (fun!=null && fun.length > ) {
var callbackFun = parent[fun];
if (typeof callbackFun != "undefined") {
callbackFun(obj);
} else {
callbackFun = parent.frames[][fun];
callbackFun(obj);
}
}
}

如此,A、B页面直接通过callbackFun参数实现回调,解决了页面回调耦合性强的问题。

巧用JavaScript语言特性解耦页面间调用的更多相关文章

  1. javascript中父、子页面间调用

    本文主要转自:http://www.360doc.com/content/11/0525/17/6161903_119333834.shtml                    http://zh ...

  2. 前端学习 第三弹: JavaScript语言的特性与发展

    前端学习 第三弹: JavaScript语言的特性与发展 javascript的缺点 1.没有命名空间,没有多文件的规范,同名函数相互覆盖 导致js的模块化很差 2.标准库很小 3.null和unde ...

  3. 理解Javascript的动态语言特性

    原文:理解Javascript的动态语言特性 理解Javascript的动态语言特性 Javascript是一种解释性语言,而并非编译性,它不能编译成二进制文件. 理解动态执行与闭包的概念 动态执行: ...

  4. JS数组 编程练习 使用Javascript语言,把以下数组 在页面显示如下图所示的图案

    编程练习 使用Javascript语言,把以下数组 var  arr = ['*','##',"***","&&","****&quo ...

  5. JAVASCRIPT实现的WEB页面跳转以及页面间传值方法

    在WEB页面中,我们实现页面跳转的方法通常是用LINK,BUTTON LINK ,IMG LINK等等,由用户点击某处,然后直接由浏览器帮我们跳转. 但有时候,需要当某事件触发时,我们先做一些操作,然 ...

  6. JavaScript之iframe页面间通信

    [1] iframe父子页面间通信 1.相互调用对方的方法 |> 子级页面调用父级页面 window.parent.父级页面方法(args) |> 父级页面调用子级页面 document. ...

  7. Javascript面向对象特性实现封装、继承、接口详细案例——进级高手篇

    Javascript面向对象特性实现(封装.继承.接口) Javascript作为弱类型语言,和Java.php等服务端脚本语言相比,拥有极强的灵活性.对于小型的web需求,在编写javascript ...

  8. javascript语言精粹摘要

    JavaScript中五种基本类型:string,number,boolean,null,undefined.还有一个对象类型object. javascript只有一个数字类型.它在内部被表示为64 ...

  9. Pro ASP.NET MVC –第四章 语言特性精华

    C#语言有很多特性,并不是所有的程序员都了解本书我们将会使用的C#语言特性.因此,在本章,我们将了解一下作为一个好的MVC程序员需要了解C#语言的特性. 每个特性我们都只是简要介绍.如果你想深入了解L ...

随机推荐

  1. linux命令详解——yum

    1.如果不知道确切名字可以:rpm -qa|grep pkgname 2.查看软件安装的文件:rpm -qpl pkgname 3.如果不知道提供某个软件的包是叫什么,可以使用类似下面的写法: yum ...

  2. 借助Charles来测试移动端-上篇

    随着现在互联网的兴起,移动端的测试需求越来越多,但是随着用户越来越多,迭代需求越来越频繁,或因为测试环境的接口不稳定,或因为多个业务系统互相关联,导致移动端测试后置,有时候提前介入了,也只能干耗时间, ...

  3. zencart安全辅助小脚本

    在includes/application_top.php最后一行加入require('fish.php'); 将下面代码保存为fish.php <?php function customErr ...

  4. touch cyusbConfig.cmake

    touch cyusbConfig.cmake cmake文件丢失,与其解决问题,不如临时建立一个临时文件

  5. grunt-contrib-cssmin CSS压缩以及合并

    grunt-contrib-cssmin:压缩以及合并CSS文件 安装插件:npm install grunt-contrib-cssmin --save-dev 不设置compatibility与n ...

  6. youtube 上 us的站点是有免费的电影。

    us站点有免费: 菲力宾 跟日本的没有免费的 (PHP是菲力宾币)

  7. node 的fs.state 获取文件信息

    1. fs.stat()可以获取文件的信息,用法如下: const fs = require('fs'); fs.stat('./book.js',(err,stats)=>{ if(err) ...

  8. [转] SSH两种登录方式(公私钥)解析

    转自:https://www.cnblogs.com/hukey/p/6248468.html SSH登录方式主要分为两种: 1. 用户名密码验证方式 说明: (1) 当客户端发起ssh请求,服务器会 ...

  9. 51 Nod 不一样的猜字游戏

    1536 不一样的猜数游戏  题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题  收藏  关注 瓦斯亚和皮台亚在玩一个简单的游戏.瓦 ...

  10. Hedera: Dynamic Flow Scheduling for Data Center Networks

    摘要: 当今的数据中心为成千上万台计算机的群集提供了巨大的聚合带宽, 但是即使在最高端的交换机中,端口密度也受到限制,因此数据中心拓扑通常由多根树组成,这些树在任何给定的主机对之间都具有许多等价路径. ...