-
你好,SO,今天我带着一个谦虚的问题来到你面前,因为我显然错过了一些相当基本的东西。
我正在尝试,但我不明白为什么它不起作用,来"扩展"一个函数。
具体而言,请考虑以下代码:console.log中的变量似乎已经丢失,即使它们已经定义。
然而,这似乎不是实现我想要实现的目标的正确方式。
要求:`用变量和方法扩展函数,以便该函数的所有新实例都将接收这些变量。您可以考虑的"类变量">
Super = function (){}; //yes it's global.
Super.prototype.alert = function()
{
console.log('alert function');
}
ExtendSuper = function(arguments) //yes it's global
{
**EDIT , THIS IS THE ANSWER THANKS TO YURY**
return function () {
return new Super(arguments);
}
}
arguments = {} //some object with variables and functions
ExtendedFunction = ExtendSuper(arguments); //yes it's global
success = new ExtendedFunction();//yes, it's global
EDIT:OP在某种程度上改变了问题,使代码示例变得无关紧要。对他来说太好了!
实际上,你对继承有一些奇怪的想法。我建议你在为时已晚之前重新考虑一下你的申请您确实需要原型,因为它们是javascript的重要组成部分。
不管怎样http://jsfiddle.net/uj4ag/
var DomDom = (function(){ //Do not need a function? Use IEFE
function View(bootstrap) //my "view" class
{ var view = this;
view.$elm = false; view.model = false;
view.render = function()
{
console.log('rendering something');
}
$.extend(view,bootstrap);
};
return {
View: View,
extend: {
View: function(params) {//Let's create a new function :)
return function() { //it is not an inheritance it is 'currying'
return new View(params);
}
}
}
}
}());
var SubClass = DomDom.extend.View({
foobar : true,
alert : function () { alert('hi')},
render : function() { console.log('rendering something else')},
});
var viewInst = new DomDom.View;
var subClassInst = new SubClass();
viewInst.render();
subClassInst.render();