wrap() 함수는 일치하는 각 요소 외부에서 지정된 HTML 구조를 래핑하는 데 사용됩니다.
이 함수의 반대는 현재 일치하는 요소의 상위 요소에 사용되는 unwrap() 함수입니다(상위 요소만 제거되고 모든 내부 노드는 유지됩니다).
이 함수는 jQuery 개체(인스턴스)에 속합니다.
Syntax
jQueryObject.wrap(wrapper)
Parameters
매개변수 설명
wrapper String/Element/jQuery/Function 유형 노드는 일치하는 요소를 래핑하는 데 사용됩니다.
매개변수 래퍼가 string인 경우 jQuery 선택기 또는 html 문자열로 간주되며 jQuery가 자체적으로 판단합니다.
jQuery 1.4의 새로운 지원: 매개변수 래퍼는 함수일 수 있습니다. Wrap()은 일치하는 모든 요소를 기반으로 함수를 순회하고 실행하며, 함수의 이 요소는 해당 DOM 요소를 가리킵니다.
wrap()은 또한 일치하는 요소에 있는 현재 요소의 인덱스인 매개변수를 함수에 전달합니다. function의 반환 값은 래핑에 사용되는 노드 콘텐츠입니다(html 문자열, DOM 요소 또는 jQuery 객체일 수 있음).
참고: 래퍼가 여러 요소와 일치하는 경우 첫 번째 요소만 래핑 요소로 사용됩니다.
참고: 래퍼가 다중 레벨 중첩 요소인 경우(예:
), Wrap()은 각 중첩 레벨의 첫 번째 요소를 확인합니다. 외부에서. 노드. 노드에 자식 노드가 없거나 첫 번째 자식 노드가 Element 노드(예: 텍스트 노드, 주석 노드 등)가 아닌 경우 내부 검색을 중지하고 현재 일치하는 요소를 내부 끝 위치에 직접 추가(append())합니다. 현재 노드.
반환 값
wrap() 함수의 반환 값은 jQuery 유형으로, 현재 jQuery 개체 자체를 반환합니다(체인 스타일 프로그래밍을 용이하게 하기 위해).
참고: 래퍼 요소가 현재 페이지의 요소인 경우에도 해당 요소는 원래 위치에서 사라지지 않습니다. Wrap()은 요소의 복사본(복제본)을 사용하여 래퍼 역할을 하기 때문입니다.
예제 및 설명
wrap() 함수는 일치하는 각 요소 앞에 콘텐츠를 삽입하는 데 사용됩니다.
<p>段落文本1<span></span></p> <p>段落文本2<span></span></p> <script type="text/javascript"> $("p").wrap( '<div></div>' ); </script> <!--以下是jQuery代码执行后的html内容--> <div><p>段落文本1<span></span></p></div> <div><p>段落文本2<span></span></p></div>
다음 HTML 코드를 예로 들어보세요.
<p id="n1"> <span id="n2">span#n2</span> </p> <p id="n3"> <input id="n4" type="text" /> </p> <span id="n5">多层嵌套1</span> <span id="n6">多层嵌套2</span>
다음 jQuery 샘플 코드는 Wrap() 함수를 시연하는 데 사용됩니다. 구체적인 사용법:
// 在n2元素外包裹strong元素:<strong>{#n2}</strong> $("#n2").wrap('<strong/>');// 在n4元素外包裹form元素:<form name="myForm">{#n4}</form> $("#n4").wrap('<form name="myForm"></form>'); // 在每个p元素外包裹div元素:<div data_id="index">{p}</div> $("p").wrap( function(index){ return '<div data_id="' + index + '"></div>'; } ); // 在n5元素外包裹嵌套的div元素:<div><p><em><b>{#n5}</b></em></p></div> $("#n5").wrap( '<div><p><em><b></b></em></p></div>' ); // 在n6元素外包裹嵌套的div元素:<div><p> <em><b></b></em>${#n5}</p></div> // wrap()会从外层div依次往内部查找,以确定n5元素的所在位置 // wrap()将从外往内检查每层嵌套的第一个元素,如果该元素没有子元素或者第一个子元素不是Element节点,就停止向内查找 // 由于参数的'<p>'后面有空格(文本节点),也就是说p元素的第一个子元素不是Element类型,因此直接将n6插入到p元素内部的末尾位置 $("#n6").wrap( '<div><p> <em><b></b></em></p></div>' ); wrap()会将包裹元素的开始标记和结束标记分别置于匹配元素的两侧,不会额外添加任何空白字符,上述代码执行后的完整html代码如下(格式未作任何调整): <div data_id="0"><p id="n1"> <strong><span id="n2">span#n2</span></strong> </p></div> <div data_id="1"><p id="n3"> <form name="myForm"><input id="n4" type="text"></form> </p></div> <div><p><em><b><span id="n5">多层嵌套1</span></b></em></p></div> <div><p> <em><b></b></em><span id="n6">多层嵌套2</span></p></div>
위 내용은 jQuery.wrap() 함수에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!