-2

エラーが見つかりません。あなたはそれを手に入れていますか?

gt (取得)、add (追加)、rm (削除) の 3 つのメソッドを持つオブジェクトとして定義されたオブジェクトが表示されます。その後、イベントハンドラー (Ev) を 1 つのことだけで追加しました: ページロードでロードし、要素 (elm) にクリックイベントを追加します。

var Obj = {
  gt: function(elm) {
    if (typeof === "string") {
    return document.getElementById(elm);  
    } else {
      return elm;
    }
  },
  add: function(elm, dst) {
    var elm = this.gt(elm);
    var dst = this.gt(dst);
    dst.appendChild(elm);
  },
  rm: function(elm) {
    var elm = this.gt(elm);
    elm.parentNode.removeChild(elm);
  }
};

var Ev = {
  add: function () {
    if (window.addEventListener) {
      return function(elm, type, fn) {
        Obj.gt(elm).addEventListener(type, fn, false);
      };
      // IE  <8 Suppport
    } else if (window.attachEvent) {
      return function(elm, type, fn){
        var f = function() {
          fn.call(Obj.gt(elm), window.event);
        };
        Obj.gt(elm).attachEvent('on' + type, f);
      };
    }
  }()
};

Ev.add(window, "load", function(){
 Ev.add("src", "click", function(){ // Source-Div with id "src"
  var elm = document.createElement("p");
  elm.innerHTML = "Test"; 
  Obj.add(elm, "dst"); // Destination-Div with id "dst"
  );
 });
});
4

1 に答える 1

4

あなたは言葉を逃した:

if (typeof === "string") {

する必要があります

if (typeof elm === "string") {
于 2013-08-06T09:19:04.383 に答える