例如:
for(var i = 0; i < _msg.length; i++){
var _div = document.createElement('<div>');
var _a = document.createElement('<span>');
_a.style.cursor="pointer";
_a.innerText = _msg[i].title;
_a.style.textDecoration ='underline';
_a.attachEvent('onclick',function(){
window.open(_a.id);
});
_a.attachEvent('onmouseover',function(){
_a.style.color="red";
});
_a.attachEvent('onmouseout',function(){
_a.style.color="#000000";
});
_a.id = 'http://<%=request.getLocalAddr()%>:8890/itsm/kb/kbAction.action?processObject.id='+ _msg[i].proObjId +'&processObject.working=false&form.id=kb_query_form&isPrint=1';
_div.appendChild (_a);
document.getElementById('kbs').appendChild (_div);
}
上面这段代码循环创建了N个对象,并注册了相应的事件,但这段代码由于有作用域的问题所以在发生事件的时候,始终是最后一个对象发生作用。
原因:_a实际上是当发生事件的时候才从作用域取出。当事件发生的时候,原来的函数已经执行完毕,因此_a的值等于最后一个,所以就会看到始终是在最后一个对象上起作用。
解决方法:
把事件注册移到独立的函数上去,让该函数保存相应的副本。
for(var i = 0; i < _msg.length; i++){
var _div = document.createElement('<div>');
var _a = document.createElement('<span>');
_a.style.cursor="pointer";
_a.innerText = _msg[i].title;
_a.style.textDecoration ='underline';
regEvent(_a, "onclick");
regEvent(_a, "onmouseover", 'red');
regEvent(_a, "onmouseout", '#000000');
_a.id = 'http://<%=request.getLocalAddr()%>:8890/itsm/kb/kbAction.action?processObject.id='+ _msg[i].proObjId +'&processObject.working=false&form.id=kb_query_form&isPrint=1';
_div.appendChild (_a);
document.getElementById('kbs').appendChild (_div);
}
function regEvent(_obj, _eventName, _styleValue){
if(_styleValue){
_obj.attachEvent(_eventName, function(){
setColor(_obj, _styleValue);
});
}else{
_obj.attachEvent(_eventName, function (){
window.open(_obj.id);
});
}
}
function setColor(_a, _value){
_a.style.color = _value;
}
分享到:
相关推荐
JavaScript 变量作用域详解 JavaScript 变量作用域是基于其特有的作用域链的。在 JavaScript 中,变量作用域是指变量可以被访问和修改的范围。 JavaScript 没有块级作用域,而是基于函数作用域和全局作用域的。 ...
JavaScript作用域是编程中至关重要的概念,它规定了变量和函数的可见性及生命周期。JavaScript主要有两种作用域:全局作用域和局部作用域。 全局作用域是指在代码的任何位置都可以访问的变量或函数,这通常包括在最...
### JavaScript 变量作用域详解 #### 一、引言 在探讨JavaScript的面向对象特性之前,理解变量作用域的概念至关重要。本篇文章旨在通过一系列示例和解释,帮助读者掌握JavaScript中的变量作用域机制。 #### 二、...
JavaScript 执行环境和作用域的深层次理解 在 JavaScript 中,执行环境和作用域是两个非常重要和基本的概念,理解了这两个概念对于 JavaScript 中很多脚本的运行结果就能明白其中的道理了。执行环境是一个概念,一...
讨论javascript作用域,很多人被javascript作用域搞迷糊了,这个应该有用。
深化理解javascript作用域其次篇之词法作用域和动态作用域_ 深化理解javascript作用域其次篇之词法作用域和动态作用域,是javascript中非常重要的一部分。理解词法作用域和动态作用域对javascript的编程至关重要。...
JavaScript作用域是编程中至关重要的概念,它定义了变量、函数和对象的可见性和生命周期。在JavaScript中,作用域主要分为两种类型:全局作用域和局部作用域。此外,随着ES6的引入,块级作用域和函数作用域也变得...
JavaScript作用域是指在JavaScript代码中,变量、常量、对象和函数能够访问的范围。在编程中,变量和函数的使用都受到作用域的限制,决定了它们能够在哪些代码块中被引用。作用域有助于防止变量命名冲突,也使得程序...
// 全局作用域:在script之间或者一个独立的js文件 script之间或者一个独立的js文件里的内容区域,在全局作用域中定义的作用域 全局作用域。 在任何位置都可以访问 // 局部变量:在函数作用域之间里的一个或者...
JavaScript 作用域是编程中一个至关重要的概念,它规定了变量和函数的有效范围,即它们在哪里可以被访问和使用。理解作用域对于编写可维护和高效的代码至关重要。本文将深入探讨 JavaScript 的全局作用域和局部作用...
本文将从JavaScript权威指南出发,深入探讨变量作用域的相关知识点,包括全局作用域、局部作用域、以及闭包等高级概念。 #### 二、全局作用域与局部作用域 1. **全局作用域** - 定义:在JavaScript中,如果一个...
作用域是JavaScript最重要的概念之一,想要学好JavaScript就需要理解JavaScript作用域和作用域链的工作原理。今天这篇文章对JavaScript作用域和作用域链作简单的介绍,希望能帮助大家更好的学习JavaScript。任何程序...
JavaScript作用域是编程中至关重要的概念,尤其是在JavaScript这种动态类型的脚本语言中。它规定了变量、函数以及其它标识符的可见性和生命周期,是代码组织和管理的关键元素。本资料"深入理解JavaScript作用域共12...
Javacript 中有一系列作用域的概念。对于新的JS的开发人员无法理解这些概念,甚至一些经验丰富的开发者也未必能。这篇文章主要目的帮助理解JavaScript中的一些概念如:scope,closure, this, namespace, function ...
JavaScript作用域是编程中至关重要的概念,它规定了变量和函数的可见性和生命周期。了解JavaScript作用域对于编写高效、安全的代码至关重要。本篇将详细解释JavaScript作用域的几个核心特性,包括无块级作用域、函数...
JavaScript中的闭包、匿名函数和作用域链是编程中至关重要的概念,它们是理解JavaScript运行机制的关键。在本文中,我们将深入探讨这三个概念,并通过实际示例来展示它们的运用。 首先,我们来讨论“闭包”。闭包是...