getElementByIdメソッドを使用せずに要素の存在をどのようにテストしますか?
参考のためにライブデモをセットアップしました。ここにもコードを印刷します。
<!DOCTYPE html>
<html>
<head>
    <script>
    var getRandomID = function (size) {
            var str = "",
                i = 0,
                chars = "0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";
            while (i < size) {
                str += chars.substr(Math.floor(Math.random() * 62), 1);
                i++;
            }
            return str;
        },
        isNull = function (element) {
            var randomID = getRandomID(12),
                savedID = (element.id)? element.id : null;
            element.id = randomID;
            var foundElm = document.getElementById(randomID);
            element.removeAttribute('id');
            if (savedID !== null) {
                element.id = savedID;
            }
            return (foundElm) ? false : true;
        };
    window.onload = function () {
        var image = document.getElementById("demo");
        console.log('undefined', (typeof image === 'undefined') ? true : false); // false
        console.log('null', (image === null) ? true : false); // false
        console.log('find-by-id', isNull(image)); // false
        image.parentNode.removeChild(image);
        console.log('undefined', (typeof image === 'undefined') ? true : false); // false ~ should be true?
        console.log('null', (image === null) ? true : false); // false ~ should be true?
        console.log('find-by-id', isNull(image)); // true ~ correct but there must be a better way than this?
    };
    </script>
</head>
<body>
    <div id="demo"></div>
</body>
</html>
基本的に上記のコードは、要素が変数に格納され、その後DOMから削除されることを示しています。要素がDOMから削除されていても、変数は最初に宣言されたときの要素を保持します。つまり、要素自体へのライブ参照ではなく、レプリカです。その結果、変数の値(要素)の存在を確認すると、予期しない結果が生じます。
このisNull関数は、変数から要素の存在を確認するための私の試みであり、機能しますが、同じ結果を達成する簡単な方法があるかどうか知りたいです。
PS:この話題に関連する優れた記事を誰かが知っている場合、JavaScript変数がこのように動作する理由にも興味があります。