> 웹 프론트엔드 > JS 튜토리얼 > IE에서만 ClearAttributes/mergeAttributes 메소드 사용을 지원합니다. Introduction_javascript 기술

IE에서만 ClearAttributes/mergeAttributes 메소드 사용을 지원합니다. Introduction_javascript 기술

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-05-16 17:53:50
원래의
1534명이 탐색했습니다.

1. .clearAttributes()

이 메소드는 모든 사용자 정의 속성을 지우는 데 사용됩니다. 다음과 같습니다

코드를 복사합니다 코드는 다음과 같습니다.

Division

<script> <br>var div = document.getElementsByTagName ('div') [0]; <br>alert(div.outerHTML); <br>div.clearAttributes() <br>alert(div.outerHTML) <br><br> </div> 실행 후 아래와 같은 창이 뜹니다 <br> <p><img alt="" src="http://files.jb51.net/file_images/article/201205/201205041604122.png"> </p> <p><img alt="" src="http://files.jb51.net/file_images/article/201205/201205041604123.png"> </p>보시다시피 두 번째 경고에 의해 생성된 외부 HTML에는 더 이상 "data-a", "data-b" 및 "onclick=alert(1)" 속성이 없습니다. 처음 두 속성은 사용자 정의되는 반면 onclick은 자체 속성이지만 지워집니다. <p><br>outerHTML이 지워지더라도 이벤트가 실제로 지워지는 것은 아닙니다. div를 클릭하면 여전히 팝업이 표시됩니다. 1. (참고: id, name, style 등 요소의 자유 속성은 삭제되지 않습니다.) <br> 위에서 확인된 바에 따르면 onclick 속성은 externalHTML에서 삭제되지만 이벤트 핸들러는 삭제되지 않으며 여전히 클릭이 가능합니다. 트리거되었습니다. 그럼 AttachEvent를 통해 추가된 이벤트를 지울 수 있나요? 사용해 보시면 알 수 있습니다<br><br></p> <div class="codetitle"><span><a style="CURSOR: pointer" data="89165" class="copybut" id="copybut89165" onclick="doCopy('code89165')">코드 복사<u></u></a> 코드는 다음과 같습니다.</span></div> <div class="codebody" id="code89165"><div&gt ;division</div> <br><script> <br>var div = document.getElementsByTagName('div')[0] <br>div.attachEvent('onclick', function(){alert(1) }); <br>div.clearAttributes(); <br></script>

테스트 결과 IE6/7/8에서는 div가 팝업되지 않는 것으로 나타났습니다. IE9에서는 여전히 팝업됩니다. 즉, IE9에서는 attachmentEvent에 의해 추가된 이벤트 핸들러를 clearAttributes를 통해 지울 수 없습니다.

2. .mergeAttributes()

이 메소드는 속성, 이벤트 및 스타일을 포함하여 지정된 요소의 모든 속성을 자체에 복사하는 데 사용됩니다. 다음과 같습니다

코드 복사 코드는 다음과 같습니다.
Division

단락


<script> <br>var div = document.getElementsByTagName('div')[0]; <br>var p = document.getElementsByTagName('p')[0]; <br>alert(p.outerHTML); .mergeAttributes(div ); <br>alert(p.outerHTML) <br></script>
첫 번째 p의 외부HTML을 복사합니다

p의 외부 HTML 복사

비교해 보면 div의 스타일(styles), onclick(이벤트), data-a(사용자 정의 속성)가 모두 p에 복사되는 것을 볼 수 있습니다. 이제 p를 클릭하면 1에도 경고할 수 있습니다.

조심스럽게 공부하는 학생들은 div의 ID가 복사되지 않는다는 것을 알게 될 것입니다. 실제로 IE5 이전에는 속성이 읽기 전용이었고 ID/이름이 병합되지 않았습니다. IE5.5 이후에는 두 번째 매개변수 값을 지정하여 id/name 속성을 복사할지 여부를 결정할 수 있습니다.

ID/이름을 복사하려면 mergeAttributes의 두 번째 매개변수를 false로 지정하면 됩니다.

p.mergeAttributes(div,false)
효과




관련:

http://msdn.microsoft.com/en-us/library/ie/ms536350(v=vs.85).aspx

http: //msdn.microsoft.com/en-us/library/ie/ms536614(v=vs.85).aspx

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿