0

我第一次尝试了log4javascript的自定义日志“appender” 。它可以工作,但它卡在原始代码中。我想将我的扩展保存在一个单独的文件中,但我对其余代码的理解不够好,无法知道如何提取它。

我知道 log4javascript 以某种方式尊重 UMD 模式,但这就是我所得到的。

(虽然不应该...

(function(root, factory){})(this, function{})...

... 代替 ...

(函数(工厂,根){})(函数{})

... ????*)

(function(factory, root) {
    if (typeof define == "function" && define.amd) {
        define(factory);
    }
    else if (typeof module != "undefined" && typeof exports == "object") {
        module.exports = factory();
    }
    else {
        root.log4javascript = factory();
    }
})(function() {

        :
  Here be dragons . . .
        :


    /*  -- -  this code works from here, but not if I    - -- */
    /*  -- -  try to move it out to a file of its own    - -- */    
    function MyAppender() {}
    MyAppender.prototype = new Appender();
    MyAppender.prototype.layout = new SimpleLayout();
    MyAppender.prototype.append = function(loggingEvent) {
      alert( this.getLayout().formatWithException(loggingEvent) );
    };
    MyAppender.prototype.toString = function() {
      return "MyAppender";
    };
    log4javascript.MyAppender = MyAppender;
    /*  -- -      -   -   -   -   -   -   -   -   -      - -- */    



        :
 . . . and sea monsters
        :


    return log4javascript;
}, this);

如何在单独的文件中对 Appender 进行子类化?

4

1 回答 1

1

自几个小时前发帖以来,我一直在阅读有关 UMD、AMD、requireJS 等的更多信息。

似乎主要问题是名称空间纯度。

弄清楚这一点后,我所要做的就是解决名称空间问题。事实证明这非常简单:它就在代码中!呸!:

log4javascript.MyAppender = MyAppender;

代替 。. .

MyAppender.prototype = new Appender();
MyAppender.prototype.layout = new SimpleLayout();

...我只需要做...

MyAppender.prototype = new log4javascript.Appender();
MyAppender.prototype.layout = new log4javascript.SimpleLayout();
于 2014-11-20T23:47:01.970 回答