时间:2021-05-25
最近这半年作为一个java 程序员,我写的javaScript代码都快比java代码多了,前段时间是给某银行做一个柜员管控系统,在柜员授权这一块功能上,由于柜员的授权需要考虑各方面的因素,比如机构权限、柜员类型权限、岗位权限,业务权限等等,并且要对这些权限要做多次的交集或者并集处理,页面上不得不用许多的javascript来进行控制。造成了这一功能模块的实现上javaScript代码比java代码负责的情况。
而现在又要给某银行开发一个保管箱管理系统,其核心功能块保管箱座管理以及保管箱管理,为实现管理功能上类似与C/S架构那样直观、方便,并将处理结果实时的显示给操作人员,经过几日思考与实验,最终使用CSS+javaScript+java来进行开发,用java来处理业务逻辑,用CSS用来表现目标对象的各种状态,用javaScript来根据目标对象的状态转变,来实现其CSS的切换。
在这其中遇到了一个难题,就是在javaScript中给一个html元素注册click事件处理函数时,比如给该处理函数传3个参数。可是不管是使用下面那种方式(node表示要注册事件的节点,fun为事件处理函数)都不能给事件处理函数传递参数:
node.addEventListener('click', fun, false); node.attachevent('onclick', fun);Node['onclick']=fun显然以方式都不行,注意一下写法都是不正确的:
node.addEventListener('click', fun(arg1,arg2,arg3), false); node.attachevent('onclick', fun(arg1,arg2,arg3)); Node['onclick']=fun(arg1,arg2,arg3)好在读过一本书《JavaScript.DOM高级程序设计》,在这本书上找到了解决方案。首先编写一个方法:
function bindFunction(obj, func){ var args = []; for(var i =2; i < arguments.length; i++) { args.push(arguments[i]);} return function(){ func.apply(obj, args);}; };然后在自己的js库中添加如下两个方法,如有不明白的地方,可以参考《JavaScript.DOM高级程序设计》,其中该书2.3小节有该方法的说明,只是本人加了些许改动:
function bindFunction(obj, func){ var args = []; for(var i =2; i < arguments.length; i++) {args.push(arguments[i]);}return function(){func.apply(obj, args);};}; window['OYF_MARK']['bindFunction'] = bindFunction; function addEvent(node, type, listener){//使用前面的方法检查兼容性以保证平稳退化if (!isCompatible()) {return false} if (!(node = $(node))) return false;if (node.addEventListener) { //W3C的方法(冒泡事件,如果将false改为true,则为捕获事件) node.addEventListener(type, listener, false); return true;}elseif (node.attachEvent) { //MSIE的方法 node['e' + type + listener] = listener;node[type + listener] = function(){node['e' + type + listener](window.event);} node.attachEvent('on' + type, node[type + listener]); return true; }//若两种方法都不具备则返回false return false;};window['OYF_MARK']['addEvent'] = addEvent;以上两个函数为本人根据《JavaScript.DOM高级程序设计》中源代码稍作修改,添加到自己的的一个js库中,以便复用。接下来就可以使用如下方式给元素注册事件并向事件处理函数传递参数了:
//注册新的onclick事件处理函数OYF_MARK.addEvent(e,'click',OYF_MARK.bindFunction(e,getContainerDetail,x,y,containid));声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
若您线下推广店面批量导入表明分析不成功或是解决不成功,请您立即下载分析不成功或是解决不成功的报表,最终一列查询不成功的缘故,依据不成功缘故改动。实际能够点此参照
最近有网友反映关于TK免费域名注册不成功的问题,"免费.TK域名注册详细教程"可能会由于限定,甚至是教程界面的变化咱们不好注册使用。由于在之前的同类.CF与.M
最近有网友反映关于TK免费域名注册不成功的问题,"免费.TK域名注册详细教程"可能会由于限定,甚至是教程界面的变化咱们不好注册使用。由于在之前的同类.CF与.M
最近有网友反映关于TK免费域名注册不成功的问题,"免费.TK域名注册详细教程"可能会由于限定,甚至是教程界面的变化咱们不好注册使用。由于在之前的同类.CF与.M
最近有网友反映关于TK免费域名注册不成功的问题,"免费.TK域名注册详细教程"可能会由于限定,甚至是教程界面的变化咱们不好注册使用。由于在之前的同类.CF与.M