1. JavaScript는 페이지에 DOM 노드가 있는지 확인합니다.
JavaScript 기본 함수는 DOM 노드가 있는지 확인하는 방법을 제공하지 않습니다. 일반적으로 객체를 반환하는 document.getElement.. 메서드를 통해 DOM 노드를 얻습니다. 객체[0], 객체[1]을 전달하여 이 컬렉션의 각 객체에 액세스할 수 있습니다. 배열 집합이 반환되므로 길이 속성이 있고 길이가 1보다 크거나 같다는 것은 DOM 노드가 페이지에 존재한다는 것을 의미합니다. 코드:
Object.prototype.exist = function(){ if(typeof this !='undefined' && this.length>=1){ return true; } return false; };
Usage:
<p>这里是p节点</p> <p>这里是p节点</p> <span>这里是span节点</span>
노드가 페이지에 있는지 확인:
var is_exist = document.getElementsByTagName('p').exist(); alert(is_exist); // true var is_exist = document.getElementsByTagName('span').exist(); alert(is_exist); // true var is_exist = document.getElementsByTagName('p').exist(); alert(is_exist); // false
document.getElementById() 메서드를 사용하여 객체를 얻는 경우에는exist( ) 메소드, ID를 기반으로 노드 객체를 얻는 방법이 이기 때문에 노드를 획득할 수 없으면 빈 객체가 반환되고 프로토타입exist() 함수가 통합되지 않으므로 오류가 보고됩니다! 따라서 ID를 기반으로 개체를 가져오는 경우 if(obj)를 직접 사용하여 페이지에 DOM 노드가 있는지 확인할 수 있습니다2. jQuery는 페이지에 DOM 노드가 있는지 확인합니다
프로토타입 추가:
(function($) { $.fn.exist = function(){ if($(this).length>=1){ return true; } return false; }; })(jQuery);
사용법:
페이지에 다음 DOM 노드가 있는 경우
这里是id=a节点
<p>这里是p节点</p> <p>这里是p节点</p> <span>这里是span节点</span>
판사:
alert($('#aaa').exist()); // false alert($('#a').exist()); // true alert($('p').exist()); // true alert($('p').exist()); // false
위의 두 가지 방법은 실제로 개체 컬렉션의 길이 속성을 기반으로 개체가 존재하는지 여부를 확인합니다.
위 내용은 javascript 및 jquery를 사용하여 dom 노드의 존재를 감지하는 방법에 대한 방법 예제에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!