是否可以访问构造函数对象/函数的属性而无需先从中创建实例?
例如,假设我有这个构造函数:
function Cat() {
this.legs = 4;
};
现在 - 没有创建新的cat实例 - 我想知道构造函数中legs
的值是什么。这可能吗?
(而且我不是在寻找像var legs = new Cat().legs
这样的东西。(假设由于某种原因,新Cat的实例化是超级CPU昂贵的。)
答案 0 :(得分:4)
这样的事情算了吗?
function Cat() {
this.legs = 4;
}
var obj = {};
Cat.call(obj);
console.log(obj.legs); // 4
答案 1 :(得分:1)
在您的方案中,leg
是一个实例变量,这意味着需要一个对象实例才能访问它。
您可以将其设为伪 - class variable
(请参阅class variable in Javascript),然后您应该可以在不调用函数的情况下访问它(实例化对象)。
答案 2 :(得分:1)
这更贵:
console.log(parseInt(Cat.toString().match(/this\.legs\s*=\s*(\d+)/)[1]));
答案 3 :(得分:1)
有一百种方法可以做到这一点,但下面的静态默认模式与其中任何一种一样好:
function Cat(opts) {
var options = opts || {};
this.legs == options.legs || Cat.defaults.legs;
};
Cat.defaults = {
legs: 4
}
var myCat = new Cat({legs:3}); //poor guy
var normalNumberOfCatLegs = Cat.defaults.legs;
答案 4 :(得分:0)
简而言之,如果没有创建它的实例,你就无法访问该变量,但是你可以解决它:
全局变量
假设'腿'可能因应用程序运行而异,您可能希望创建一个" global"通过将分支分配给“窗口”来变量,这是一个在整个页面生命周期中都存在的对象:
window.legs = 4; // put this at the top of your script
然后在整个申请过程中,您可以更改此内容,直到您准备好在Cats()中使用它:
window.legs = user_input;
全球对象
如果您希望Cats具有其他可变属性,您甚至可以将对象分配给窗口:
window.Cat = {};
window.Cat.legs = 4;
window.Cat.has_tail = true;
window.Cat.breeds = ["siamese","other cat breed"];
如何使用Globals
然后,当稍后创建Cat对象时,您可以从窗口中提取数据以创建Cat的实例:
function Cat(){
this.legs = window.legs;
//or
this.legs = window.Cat.legs;
}
答案 5 :(得分:-3)
// cat.js
function Cat() {
}
Cat.prototype.legs = 4;
// somescript.js
var legs = Cat.prototype.legs
var cat = new Cat();
console.log(legs, cat.legs); // 4, 4