扩展一个函数并对其进行实例化-javascript

Extending a function and instantiating it - javascript

本文关键字:-javascript 实例化 函数 一个 扩展      更新时间:2023-09-26

-
你好,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();