> 웹 프론트엔드 > JS 튜토리얼 > JQuery를 기본 js로 대체하는 방법에 대한 16가지 방법의 자세한 예

JQuery를 기본 js로 대체하는 방법에 대한 16가지 방법의 자세한 예

伊谢尔伦
풀어 주다: 2017-06-17 11:46:35
원래의
1854명이 탐색했습니다.

일부 JQuery 메소드를 대체하는 네이티브 JS의 간단한 구현을 제공합니다. 꽤 좋은 것 같아서 여러분과 공유하고 참고용으로 드리고 싶습니다.

1. 요소 선택

// jQuery
var els = $('.el');

// Native
var els = document.querySelectorAll('.el');

// Shorthand
var $ = function (el) {
 return document.querySelectorAll(el);
}
로그인 후 복사

querySelectorAll 메소드는 배열로 변환해야 하는 NodeList 객체를 반환합니다.

myList = Array.prototype.slice.call(myNodeList)
로그인 후 복사
re2 클래스를 조작하는 데 사용할 수 있는 읽기 및 쓰기 가능한 className 특성입니다.

HTML 5는 또한 더 강력한 기능을 갖춘 classList 객체를 제공합니다(IE 9에서는 지원되지 않음).

// jQuery
var newEl = $(&#39;<p/>&#39;);

// Native
var newEl = document.createElement(&#39;p&#39;);
로그인 후 복사

6. 요소 추가

꼬리에 요소 추가:

// jQuery
$(&#39;.el&#39;).on(&#39;event&#39;, function() {

});

// Native
[].forEach.call(document.querySelectorAll(&#39;.el&#39;), function (el) {
 el.addEventListener(&#39;event&#39;, function() {

 }, false);
});
로그인 후 복사

머리에 요소 추가:

// jQuery
$(&#39;.el&#39;).filter(&#39;:first&#39;).attr(&#39;key&#39;, &#39;value&#39;);
$(&#39;.el&#39;).filter(&#39;:first&#39;).attr(&#39;key&#39;);

// Native
document.querySelector(&#39;.el&#39;).setAttribute(&#39;key&#39;, &#39;value&#39;);
document.querySelector(&#39;.el&#39;).getAttribute(&#39;key&#39;);
로그인 후 복사
7. 요소 복제

// jQuery
$(&#39;.el&#39;).addClass(&#39;class&#39;);
$(&#39;.el&#39;).removeClass(&#39;class&#39;);
$(&#39;.el&#39;).toggleClass(&#39;class&#39;);

// Native
document.querySelector(&#39;.el&#39;).classList.add(&#39;class&#39;);
document.querySelector(&#39;.el&#39;).classList.remove(&#39;class&#39;);
document.querySelector(&#39;.el&#39;).classList.toggle(&#39;class&#39;);
로그인 후 복사

8. 요소 제거

// jQuery
$(&#39;.el&#39;).append($(&#39;<p/>&#39;));

// Native
document.querySelector(&#39;.el&#39;).appendChild(document.createElement(&#39;p&#39;));
로그인 후 복사

9. 부모 찾기 레벨 요소

//jQuery
$(‘.el&#39;).prepend(&#39;<p></p>&#39;)

//Native
var parent = document.querySelector(&#39;.el&#39;);
parent.insertBefore("<p></p>",parent.childNodes[0])
로그인 후 복사

10. 이전/다음 요소 가져오기(이전/다음 요소)

// jQuery
var clonedEl = $(&#39;.el&#39;).clone();

// Native
var clonedEl = document.querySelector(&#39;.el&#39;).cloneNode(true);
로그인 후 복사

11. 하위 요소가 있는지 여부

Remove
// jQuery
$(&#39;.el&#39;).remove();

// Native
remove(&#39;.el&#39;);

function remove(el) {
 var toRemove = document.querySelector(el);

 toRemove.parentNode.removeChild(toRemove);
}
로그인 후 복사

14.$(document).ready

DOM 로딩이 완료되면 jQuery의 $(document).ready 메소드와 동일한 DOMContentLoaded 이벤트가 트리거됩니다.

// jQuery
$(&#39;.el&#39;).parent();

// Native
document.querySelector(&#39;.el&#39;).parentNode;
로그인 후 복사

15. 데이터 저장

jQuery 객체는 데이터를 저장할 수 있습니다.

// jQuery
$(&#39;.el&#39;).prev();
$(&#39;.el&#39;).next();

// Native
document.querySelector(&#39;.el&#39;).previousElementSibling;
document.querySelector(&#39;.el&#39;).nextElementSibling;
로그인 후 복사

HTML 5에는 비슷한 기능을 가진 데이터 세트 개체가 있지만(IE 10은 지원하지 않음) 문자열만 저장할 수 있습니다.

// jQuery
$.get(&#39;url&#39;, function (data) {

});
$.post(&#39;url&#39;, {data: data}, function (data) {

});

// Native

// get
var xhr = new XMLHttpRequest();

xhr.open(&#39;GET&#39;, url);
xhr.onreadystatechange = function (data) {

}
xhr.send();

// post
var xhr = new XMLHttpRequest()

xhr.open(&#39;POST&#39;, url);
xhr.onreadystatechange = function (data) {

}
xhr.send({data: data});
로그인 후 복사

16. Animation

jQuery의 animate 메소드를 사용하여 애니메이션 효과를 생성합니다.

//jQuery
$("#elementID").empty()

//Native
var element = document.getElementById("elementID")
while(element.firstChild) element.removeChild(element.firstChild);
로그인 후 복사
jQuery의 애니메이션 효과는 주로 DOM을 기반으로 합니다. 그러나 현재 CSS 3 애니메이션은 DOM보다 훨씬 강력하므로 CSS에 애니메이션 효과를 작성한 다음 DOM 요소의 클래스를 조작하여 애니메이션을 표시할 수 있습니다.

//jQuery
if (!$("#elementID").is(":empty")){}

//Native
if (document.getElementById("elementID").hasChildNodes()){}
로그인 후 복사

애니메이션에 콜백 함수를 사용해야 하는 경우 CSS 3에서는 해당 이벤트도 정의합니다.

아아아아

위 내용은 JQuery를 기본 js로 대체하는 방법에 대한 16가지 방법의 자세한 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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