7

私はすべてのdom要素を拡張して、子を取得および削除できるようにしようとしています。機能は以下の通りです(FFとChromeで動作します)。基本のdomオブジェクトを拡張するためのIE7に相当するものはありますか?

if (!Element.get) {
Element.prototype.get = function(id) {
    for (var i = 0; i < this.childNodes.length; i++) {
        if (this.childNodes[i].id == id) {
            return this.childNodes[i];
        }
        if (this.childNodes[i].childNodes.length) {
            var ret = this.childNodes[i].get(id);
            if (ret != null) {
                return ret;
            }
        }
    }
    return null;
}
}

Element.prototype.removeChildren = function() {
    removeChildren(this);
}

ありがとう!

4

3 に答える 3

5

これは、99% のケースで十分な簡単な回避策です。スクリプトで必要に応じて完了することもできます。

if ( !window.Element ) 
{
    Element = function(){};

    var __createElement = document.createElement;
    document.createElement = function(tagName)
    {
        var element = __createElement(tagName);
        if (element == null) {return null;}
        for(var key in Element.prototype)
                element[key] = Element.prototype[key];
        return element;
    }

    var __getElementById = document.getElementById;
    document.getElementById = function(id)
    {
        var element = __getElementById(id);
        if (element == null) {return null;}
        for(var key in Element.prototype)
                element[key] = Element.prototype[key];
        return element;
    }
}
于 2009-11-08T15:00:05.933 に答える
4

いいえ。 IE8では限定的なサポートが提供されますが、それまでは、関数をハングアップする別の場所を見つけたほうがよいでしょう。

于 2009-02-28T01:20:05.697 に答える
3

IE には "Element" が設定されていないため、Element のプロトタイプにアクセスして関数を直接追加することはできません。回避策は、「createElement」と「getElementById」をオーバーロードして、関数で変更されたプロトタイプを持つ要素を返すようにすることです。

解決策を提供してくれた Simon Uyttendaele に感謝します!

if ( !window.Element )
{
        Element = function(){}

        Element.prototype.yourFunction = function() {
                alert("yourFunction");
        }


        var __createElement = document.createElement;
        document.createElement = function(tagName)
        {
                var element = __createElement(tagName);
                for(var key in Element.prototype)
                        element[key] = Element.prototype[key];
                return element;
        }

        var __getElementById = document.getElementById
        document.getElementById = function(id)
        {
                var element = __getElementById(id);
                for(var key in Element.prototype)
                        element[key] = Element.prototype[key];
                return element;
        }
}
于 2011-07-14T04:43:00.460 に答える