- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到了一个奇怪的问题,看看下面的代码..
var ApplicationParser = (function(){
ApplicationParser.prototype.messageFramer;
ApplicationParser.prototype.isPreviousFetchingDirection;
ApplicationParser.prototype.latestDataArrays = [];
ApplicationParser.prototype.dataPointsArray = [];
ApplicationParser.prototype.chartObject;
ApplicationParser.prototype.titleLabel;
ApplicationParser.prototype.chartConfiguration;
ApplicationParser.prototype.htmlId;
function ApplicationParser(url,dataPointArray, title, htmlId,fetchSize) {
this.messageFramer = new MessageFramer(url,fetchSize);
this.isPreviousFetchingDirection = true;
this.messageFramer.FetchNextData(this,this.isPreviousFetchingDirection);
this.dataPointsArray = dataPointArray;
this.titleLabel = title;
this.htmlId = htmlId;
for (var int = 0; int < globalConfiguration.length; int++) {
var array_element = globalConfiguration[int];
this.latestDataArrays[array_element] = new Array();
}
}
return ApplicationParser; }());
var app1 = new ApplicationParser('url',dataPointArray,title,"#context", 50000);
app1.latestDataArrays = [1,2,3];
app1.dataPointsArray = [1,2,3];
var app2 = new ApplicationParser('url',dataPointArray,title,"#context", 50000);
app2.latestDataArrays = [4,5,6];
app2.dataPointsArray = [4,5,6];
现在,如果您尝试访问两个对象的“latestDataArrays”,那么它将显示 [4,5,6];而“dataPointsArray”仍然不同。为什么“latestDataArrays”也无法显示不同的值...
如果我用下面的代码替换上面的代码,那么问题就解决了......
var ApplicationParser = (function(){
ApplicationParser.prototype.messageFramer;
ApplicationParser.prototype.isPreviousFetchingDirection;
ApplicationParser.prototype.latestDataArrays = [];
ApplicationParser.prototype.dataPointsArray = [];
ApplicationParser.prototype.chartObject;
ApplicationParser.prototype.titleLabel;
ApplicationParser.prototype.chartConfiguration;
ApplicationParser.prototype.htmlId;
function ApplicationParser(url,dataPointArray, title, htmlId,fetchSize) {
this.messageFramer = new MessageFramer(url,fetchSize);
this.isPreviousFetchingDirection = true;
this.messageFramer.FetchNextData(this,this.isPreviousFetchingDirection);
this.dataPointsArray = dataPointArray;
this.titleLabel = title;
this.htmlId = htmlId;
var latArrayTemp = new Object();
for (var int = 0; int < globalConfiguration.length; int++) {
var array_element = globalConfiguration[int];
latArrayTemp[array_element] = new Array();
}
this.latestDataArrays = latArrayTemp;
}
return ApplicationParser;}());
请告诉其背后的原因是什么,是否是构造函数内的 for 循环创建问题,如果是,那么为什么......?
最佳答案
请问这背后的原因是什么,是构造函数内的for循环创建问题吗?
不,它与 for 循环无关。问题的根本原因是:
dataPointsArray
是 app1
和 app2
的实例变量——每个 ApplicationParser
对象都有自己唯一的dataPointsArray
实例。
但是,latestDataArrays
是 ApplicationParser.prototype
中的一个字段,这意味着所有 ApplicationParser
对象(app1
和app2
)将共享 latestDataArrays
实例(除非他们声明它的 latestDataArrays
指向其他内容。这正是第二个代码片段的行为)。
如何解决问题?
由于 dataPointsArray
和 latestDataArrays
是实例变量,请将它们从 ApplicationParser.prototype
中删除。即删除以下两行:
ApplicationParser.prototype.latestDataArrays = [];
ApplicationParser.prototype.dataPointsArray = [];
<小时/>
一些详细说明:
代码中发生了什么:var app = new ApplicationParser(...)
?
当调用new ApplicationParser(...)
时,执行以下步骤:
ApplicationParser.prototype
扩展。我们称之为 X。ApplicationParser
(构造函数),在函数内使用 X 作为 this
。return
语句,则返回X;应用
。app1
和 app2
会发生什么情况?
对于 var app1 = new ApplicationParser(...)
语句,我们将其“X”称为 Xapp1。
对于 var app2 = new ApplicationParser(...)
语句,我们将其“X”称为 Xapp2。
创建 Xapp1 后且在构造函数运行之前,Xapp1.dataPointsArray
指向 ApplicationParser.prototype.dataPointsArray
和 Xapp1.latestDataArrays
点到ApplicationParser.prototype.latestDataArrays
:
Xapp1.dataPointsArray === ApplicationParser.prototype.dataPointsArray // true
Xapp1.latestDataArrays === ApplicationParser.prototype.latestDataArrays // true
创建 Xapp1 并运行构造函数后,Xapp1.dataPointsArray
指向一个新对象(相应的参数,我们将其称为 D1)和 Xapp1.latestDataArrays
> 仍然指向 ApplicationParser.prototype.latestDataArrays
,因为它没有重新分配,this.latestDataArrays[array_element] = ...
仅更改对象的某些属性this.latestDataArrays
指向。
Xapp1.dataPointsArray === ApplicationParser.prototype.dataPointsArray // false, as Xapp1.dataPointsArray is D1 now.
Xapp1.latestDataArrays === ApplicationParser.prototype.latestDataArrays // true
对于Xapp2,逻辑是相同的,所以:
Xapp2.dataPointsArray === ApplicationParser.prototype.dataPointsArray // false, as Xapp2.dataPointsArray is D2 now.
Xapp2.latestDataArrays === ApplicationParser.prototype.latestDataArrays // true
因此,很明显,Xapp1 和 Xapp2 共享 latestDataArrays
对象,但它们的 dataPointsArray
是唯一的。
为什么第二个代码片段有效?
第二个代码片段之所以有效,是因为以下语句:
this.latestDataArrays = latArrayTemp;
此语句重新分配 latestDataArrays
字段,使 Xapp1 的 latestDataArrays
指向一个新对象(我们称之为 L1),而 Xapp2 的 latestDataArrays
> 指向另一个(L2)。因此:
Xapp1.latestDataArrays === ApplicationParser.prototype.latestDataArrays // false, as Xapp1.latestDataArrays is L1 now.
Xapp2.latestDataArrays === ApplicationParser.prototype.latestDataArrays // false, as Xapp2.latestDataArrays is L2 now.
这使得 Xapp1 和 Xapp2 的 latestDataArrays
独一无二。
关于javascript - 如果我在构造函数中使用 for 循环,私有(private)变量不是特定于对象的 : JavaScript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44796033/
C语言sscanf()函数:从字符串中读取指定格式的数据 头文件: ?
最近,我有一个关于工作预评估的问题,即使查询了每个功能的工作原理,我也不知道如何解决。这是一个伪代码。 下面是一个名为foo()的函数,该函数将被传递一个值并返回一个值。如果将以下值传递给foo函数,
CStr 函数 返回表达式,该表达式已被转换为 String 子类型的 Variant。 CStr(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CSng 函数 返回表达式,该表达式已被转换为 Single 子类型的 Variant。 CSng(expression) expression 参数是任意有效的表达式。 说明 通常,可
CreateObject 函数 创建并返回对 Automation 对象的引用。 CreateObject(servername.typename [, location]) 参数 serv
Cos 函数 返回某个角的余弦值。 Cos(number) number 参数可以是任何将某个角表示为弧度的有效数值表达式。 说明 Cos 函数取某个角并返回直角三角形两边的比值。此比值是
CLng 函数 返回表达式,此表达式已被转换为 Long 子类型的 Variant。 CLng(expression) expression 参数是任意有效的表达式。 说明 通常,您可以使
CInt 函数 返回表达式,此表达式已被转换为 Integer 子类型的 Variant。 CInt(expression) expression 参数是任意有效的表达式。 说明 通常,可
Chr 函数 返回与指定的 ANSI 字符代码相对应的字符。 Chr(charcode) charcode 参数是可以标识字符的数字。 说明 从 0 到 31 的数字表示标准的不可打印的
CDbl 函数 返回表达式,此表达式已被转换为 Double 子类型的 Variant。 CDbl(expression) expression 参数是任意有效的表达式。 说明 通常,您可
CDate 函数 返回表达式,此表达式已被转换为 Date 子类型的 Variant。 CDate(date) date 参数是任意有效的日期表达式。 说明 IsDate 函数用于判断 d
CCur 函数 返回表达式,此表达式已被转换为 Currency 子类型的 Variant。 CCur(expression) expression 参数是任意有效的表达式。 说明 通常,
CByte 函数 返回表达式,此表达式已被转换为 Byte 子类型的 Variant。 CByte(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CBool 函数 返回表达式,此表达式已转换为 Boolean 子类型的 Variant。 CBool(expression) expression 是任意有效的表达式。 说明 如果 ex
Atn 函数 返回数值的反正切值。 Atn(number) number 参数可以是任意有效的数值表达式。 说明 Atn 函数计算直角三角形两个边的比值 (number) 并返回对应角的弧
Asc 函数 返回与字符串的第一个字母对应的 ANSI 字符代码。 Asc(string) string 参数是任意有效的字符串表达式。如果 string 参数未包含字符,则将发生运行时错误。
Array 函数 返回包含数组的 Variant。 Array(arglist) arglist 参数是赋给包含在 Variant 中的数组元素的值的列表(用逗号分隔)。如果没有指定此参数,则
Abs 函数 返回数字的绝对值。 Abs(number) number 参数可以是任意有效的数值表达式。如果 number 包含 Null,则返回 Null;如果是未初始化变量,则返回 0。
FormatPercent 函数 返回表达式,此表达式已被格式化为尾随有 % 符号的百分比(乘以 100 )。 FormatPercent(expression[,NumDigitsAfterD
FormatNumber 函数 返回表达式,此表达式已被格式化为数值。 FormatNumber( expression [,NumDigitsAfterDecimal [,Inc
我是一名优秀的程序员,十分优秀!