原生JS取代一些JQuery方法的簡(jiǎn)單實(shí)現(xiàn)
1.選取元素
// jQuery
var els = $('.el');
// Native
var els = document.querySelectorAll('.el');
// Shorthand
var $ = function (el) {
return document.querySelectorAll(el);
}
querySelectorAll方法返回的是NodeList對(duì)象,需要轉(zhuǎn)換為數(shù)組。
myList = Array.prototype.slice.call(myNodeList)
2.創(chuàng)建元素
// jQuery
var newEl = $('<div/>');
// Native
var newEl = document.createElement('div');
3.添加事件
// jQuery
$('.el').on('event', function() {
});
// Native
[].forEach.call(document.querySelectorAll('.el'), function (el) {
el.addEventListener('event', function() {
}, false);
});
4.get/set屬性
// jQuery
$('.el').filter(':first').attr('key', 'value');
$('.el').filter(':first').attr('key');
// Native
document.querySelector('.el').setAttribute('key', 'value');
document.querySelector('.el').getAttribute('key');
5.添加和移除樣式Class
DOM元素本身有一個(gè)可讀寫的className屬性,可以用來(lái)操作class。
HTML 5還提供一個(gè)classList對(duì)象,功能更強(qiáng)大(IE 9不支持)。
// jQuery
$('.el').addClass('class');
$('.el').removeClass('class');
$('.el').toggleClass('class');
// Native
document.querySelector('.el').classList.add('class');
document.querySelector('.el').classList.remove('class');
document.querySelector('.el').classList.toggle('class');
6.追加元素
尾部追加元素:
// jQuery
$('.el').append($('<div/>'));
// Native
document.querySelector('.el').appendChild(document.createElement('div'));
頭部追加元素:
//jQuery
$(‘.el').prepend('<div></div>')
//Native
var parent = document.querySelector('.el');
parent.insertBefore("<div></div>",parent.childNodes[0])
7.克隆元素
// jQuery
var clonedEl = $('.el').clone();
// Native
var clonedEl = document.querySelector('.el').cloneNode(true);
8.移除元素
Remove
// jQuery
$('.el').remove();
// Native
remove('.el');
function remove(el) {
var toRemove = document.querySelector(el);
toRemove.parentNode.removeChild(toRemove);
}
9.獲取父級(jí)元素
// jQuery
$('.el').parent();
// Native
document.querySelector('.el').parentNode;
10.獲取上一個(gè)/下一個(gè)元素(Prev/next element)
// jQuery
$('.el').prev();
$('.el').next();
// Native
document.querySelector('.el').previousElementSibling;
document.querySelector('.el').nextElementSibling;
11.XHR and AJAX
// jQuery
$.get('url', function (data) {
});
$.post('url', {data: data}, function (data) {
});
// Native
// get
var xhr = new XMLHttpRequest();
xhr.open('GET', url);
xhr.onreadystatechange = function (data) {
}
xhr.send();
// post
var xhr = new XMLHttpRequest()
xhr.open('POST', url);
xhr.onreadystatechange = function (data) {
}
xhr.send({data: data});
12.清空子元素
//jQuery
$("#elementID").empty()
//Native
var element = document.getElementById("elementID")
while(element.firstChild) element.removeChild(element.firstChild);
13.檢查是否有子元素
//jQuery
if (!$("#elementID").is(":empty")){}
//Native
if (document.getElementById("elementID").hasChildNodes()){}
14.$(document).ready
DOM加載完成,會(huì)觸發(fā)DOMContentLoaded事件,等同于jQuery的$(document).ready方法。
document.addEventListener("DOMContentLoaded", function() {
// ...
});
15.數(shù)據(jù)儲(chǔ)存
jQuery對(duì)象可以儲(chǔ)存數(shù)據(jù)。
$("body").data("foo", 52);
HTML 5有一個(gè)dataset對(duì)象,也有類似的功能(IE 10不支持),不過只能保存字符串。
element.dataset.user = JSON.stringify(user); element.dataset.score = score;
16.動(dòng)畫
jQuery的animate方法,用于生成動(dòng)畫效果。
$foo.animate('slow', { x: '+=10px' }
jQuery的動(dòng)畫效果,很大部分基于DOM。但是目前,CSS 3的動(dòng)畫遠(yuǎn)比DOM強(qiáng)大,所以可以把動(dòng)畫效果寫進(jìn)CSS,然后通過操作DOM元素的class,來(lái)展示動(dòng)畫。
foo.classList.add('animate')
如果需要對(duì)動(dòng)畫使用回調(diào)函數(shù),CSS 3也定義了相應(yīng)的事件。
el.addEventListener("webkitTransitionEnd", transitionEnded);
el.addEventListener("transitionend", transitionEnded);
以上就是小編為大家?guī)?lái)的原生JS取代一些JQuery方法的簡(jiǎn)單實(shí)現(xiàn)的全部?jī)?nèi)容了,希望對(duì)大家有所幫助,多多支持腳本之家~
- jQuery實(shí)現(xiàn)隔行變色的方法分析(對(duì)比原生JS)
- 原生js仿jquery實(shí)現(xiàn)對(duì)Ajax的封裝
- 原生js仿jquery一些常用方法(必看篇)
- 原生js封裝的一些jquery方法(詳解)
- 原生js實(shí)現(xiàn)jquery函數(shù)animate()動(dòng)畫效果的簡(jiǎn)單實(shí)例
- 原生js仿jquery animate動(dòng)畫效果
- 原生js和jquery分別實(shí)現(xiàn)橫向?qū)Ш讲藛涡Ч?/a>
- 原生JS和jQuery版實(shí)現(xiàn)文件上傳功能
- 使用jQuery或者原生js實(shí)現(xiàn)鼠標(biāo)滾動(dòng)加載頁(yè)面新數(shù)據(jù)
- 原生js和jQuery實(shí)現(xiàn)淡入淡出輪播效果
- 原生js與jQuery實(shí)現(xiàn)簡(jiǎn)單的tab切換特效對(duì)比
- 詳解用原生JavaScript實(shí)現(xiàn)jQuery的某些簡(jiǎn)單功能
相關(guān)文章
基于JavaScript實(shí)現(xiàn)瀑布流效果(循環(huán)漸近)
本文給大家介紹基于javascript實(shí)現(xiàn)循環(huán)漸近瀑布流效果,代碼簡(jiǎn)單易懂,非常具有參考價(jià)值,需要的朋友參考下吧2016-01-01
使用Fullpage插件快速開發(fā)整屏翻頁(yè)的頁(yè)面
這篇文章給大家分析使用Fullpage插件快速開發(fā)整屏翻頁(yè)的頁(yè)面,適用于各大網(wǎng)站,此功能非常高大上,下面就跟隨腳本之家小編看看Fullpage插件是怎么實(shí)現(xiàn)此效果的2017-09-09
微信小程序開發(fā)WXML模板語(yǔ)法基礎(chǔ)教程
這篇文章主要介紹了微信小程序模板語(yǔ)法,WXML(WeiXin?Markup?Language)是框架設(shè)計(jì)的一套標(biāo)簽語(yǔ)言,結(jié)合基礎(chǔ)組件、事件系統(tǒng),可以構(gòu)建出頁(yè)面的結(jié)構(gòu),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
ligerUI---ListBox(列表框可移動(dòng)的實(shí)例)
下面小編就為大家分享一篇ligerUI---ListBox(列表框可移動(dòng)的實(shí)例),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2017-11-11
微信小程序?qū)崿F(xiàn)下滑到底部自動(dòng)翻頁(yè)功能
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)下滑到底部自動(dòng)翻頁(yè)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03
解析JavaScript實(shí)現(xiàn)DDoS攻擊原理與保護(hù)措施
本文主要對(duì)JavaScript實(shí)現(xiàn)DDoS攻擊原理與保護(hù)措施進(jìn)行介紹,具有一定的參考價(jià)值,需要的朋友一起來(lái)看下吧2016-12-12
javascript語(yǔ)句中的CDATA標(biāo)簽的意義
javascript語(yǔ)句中的CDATA標(biāo)簽的意義...2007-05-05

