我已经开始尝试学习如何更广泛地使用 JavaScript 对象,并且我一直在尝试用 JavaScript 编写一个对象,它允许我在初始化时设置一些构造函数参数。
我不得不说,JavaScript 中有很多不同的“设计模式”,我可能把自己与语法和诸如此类的东西搞混了。通过我的研究,我发现了各种 StackOverflow 文章,例如:
我想对我的对象做些什么在初始化时设置一些内部/私有变量,如下所示:
<script>
var TestObj = new Dispatch( 100 );
console.log( TestObj.getConstructorValue() );
//Would Return 100.
</script>
虽然目前,对象的构建方式在Test
初始化后尝试访问它时当前返回未定义:
<script>
$(document).on('ready', function(){
var TestObj = new Dispatch( 100 );
//Set post-initialised variables & set to '5'
TestObj.setOrderNumber( 5 );
//Retrieves 5
console.log( "Accessing Property: " + TestObj.OrderNumber );
//Method for getting orderNumber Property, Returns 5
console.log( "Method for Order Number: " + TestObj.getOrderNumber() );
//Method for getting would-be constructor value
console.log( TestObj.getTest() ); //Returns Undefined
console.log( TestObj.Test ); //Returns Undefined
});
</script>
JavaScript
<script>
/**
*
**/
var Dispatch = function( Arg1 ) {
var OrderNumber;
var Test;
var setOrderNumber = function( orderNum ) {
this.OrderNumber = orderNum;
};
this.constructor = function( str ) {
this.Test = str;
};
this.constructor( Arg1 );
return {
/**
* Getter for OrderNumber
**/
getOrderNumber : function(){
return this.OrderNumber;
},
/**
* Setter for OrderNumber
**/
setOrderNumber : setOrderNumber,
/**
* Getter for Test
**/
getTest : function() {
return this.Test;
}
};
};
</script>
我试过的(一)
我试图直接设置它:
<script>
var Dispatch = function( s ) {
/**
* Assign constructor
* to Test
**/
var Test = s;
return {
getTest : function() {
return this.Test;
}
}
};
TestObj.getTest(); //Returns undefined
</script>
我试过的(2)
我还尝试通过稍微混合函数返回来访问变量:
<script>
var Dispatch = function( s ) {
var Test;
var getTestVar = function() {
return this.Test;
}
this.constructor = function( str ) {
this.Test = str;
};
/**
*
**/
this.constructor( s );
return {
getTest : getTestVar
};
};
TestObj.getTest(); //Returns undefined
</script>
不过,我玩弄了其他方法,如果能以书面形式理解为什么我让构造函数工作出错了,那就太好了。
这是一个jsFiddle,它显示了所有这些。为相当长的帖子和我的 JavaScript 对象无知道歉!