巧用JavaScript语言特性解耦页面间调用
一个很小的技巧,留下一笔,供日后查看。
业务场景:
一个页面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语言特性解耦页面间调用的更多相关文章
- javascript中父、子页面间调用
本文主要转自:http://www.360doc.com/content/11/0525/17/6161903_119333834.shtml http://zh ...
- 前端学习 第三弹: JavaScript语言的特性与发展
前端学习 第三弹: JavaScript语言的特性与发展 javascript的缺点 1.没有命名空间,没有多文件的规范,同名函数相互覆盖 导致js的模块化很差 2.标准库很小 3.null和unde ...
- 理解Javascript的动态语言特性
原文:理解Javascript的动态语言特性 理解Javascript的动态语言特性 Javascript是一种解释性语言,而并非编译性,它不能编译成二进制文件. 理解动态执行与闭包的概念 动态执行: ...
- JS数组 编程练习 使用Javascript语言,把以下数组 在页面显示如下图所示的图案
编程练习 使用Javascript语言,把以下数组 var arr = ['*','##',"***","&&","****&quo ...
- JAVASCRIPT实现的WEB页面跳转以及页面间传值方法
在WEB页面中,我们实现页面跳转的方法通常是用LINK,BUTTON LINK ,IMG LINK等等,由用户点击某处,然后直接由浏览器帮我们跳转. 但有时候,需要当某事件触发时,我们先做一些操作,然 ...
- JavaScript之iframe页面间通信
[1] iframe父子页面间通信 1.相互调用对方的方法 |> 子级页面调用父级页面 window.parent.父级页面方法(args) |> 父级页面调用子级页面 document. ...
- Javascript面向对象特性实现封装、继承、接口详细案例——进级高手篇
Javascript面向对象特性实现(封装.继承.接口) Javascript作为弱类型语言,和Java.php等服务端脚本语言相比,拥有极强的灵活性.对于小型的web需求,在编写javascript ...
- javascript语言精粹摘要
JavaScript中五种基本类型:string,number,boolean,null,undefined.还有一个对象类型object. javascript只有一个数字类型.它在内部被表示为64 ...
- Pro ASP.NET MVC –第四章 语言特性精华
C#语言有很多特性,并不是所有的程序员都了解本书我们将会使用的C#语言特性.因此,在本章,我们将了解一下作为一个好的MVC程序员需要了解C#语言的特性. 每个特性我们都只是简要介绍.如果你想深入了解L ...
随机推荐
- 如何使用python生成gif
如何使用python生成gif? 在我的文件夹里面有很多图片,我们如何将其合成一个gif呢?可以使用PIL模块,这个模块在我的"python图像处理"板块中有详细介绍. # -*- ...
- 测试人员必备:linux文件清理不得不知道的技巧
测试人员最常见和繁琐的任务之一就是清理系统,比如防止磁盘空间出现不足.下面是我收集的一些常用的 Linux 文件系统相关命令. 一 检查可用空间 要查找服务器上所有文件系统上的可用空间,请执行以下命令 ...
- 局部处理的边缘连接(python+opencv)
rt import cv2 import numpy as np path = "_lo.png" img = cv2.imread(path) gray = cv2.cvtCol ...
- 交互式数据可视化-D3.js(三)比例尺
线性比例尺 线性比例尺是常用比例尺常用方法有: var linear = d3.scaleLinear() - 创建一个定量的线性比例尺. linear.domain([numbers]) - 定义或 ...
- Vue打包上线之后CSS没有压缩和不生效
前言 当用vue-cli 脚手架 打包压缩时,发现打包出来的css 没有被压缩, 所以查阅了些资料,下面用这个方法解决: 1.首先注释掉webpack.prod.conf.js中下面的代码 new O ...
- 初识linux(简单命令)
之前一直搞不懂,为什么全是命令行的linux系统这么多公司都在用,当你看不懂那一行行命令时你一定会和我一样觉得头大.但当你学习了命令再结合桌面版觉得linux还是挺不错的
- Python实现ANSI文件转UTF-8
ANSI编码的文件转为UTF-8编码的文件. # ANSI文件转UTF-8 import codecs import os # 文件所在目录 file_path = "H:\Python\S ...
- 【leetcode】1268. Search Suggestions System
题目如下: Given an array of strings products and a string searchWord. We want to design a system that su ...
- react-报错-1
react 错误提示:显示IP端口被占用
- [HG]腿部挂件 题解
前言 暴力跑的比正解快. 以下暴力(循环展开+fread读入输出优化) #include<cstdio> #pragma GCC optimize(3, "Ofast" ...