一、选取 DOM 元素
jQuery 的核心是通过各种选择器,选中 DOM 元素,可以用 querySelectorAll 方法模拟这个功能。
var $ = document.querySelectorAll.bind (document);
这里需要注意的是,querySelectorAll 方法返回的是 NodeList 对象,它很像数组(有数字索引和 length 属性),但不是数组,不能使用 pop、push 等数组特有方法。如果有需要,可以考虑将 Nodelist 对象转为数组。
myList = Array.prototype.slice.call (myNodeList);
二、DOM 操作
DOM 本身就具有很丰富的操作方法,可以取代 jQuery 提供的操作方法。
尾部追加 DOM 元素。
// jQuery 写法 $(parent).append ($(child)); // DOM 写法 parent.appendChild (child);
头部插入 DOM 元素。
// jQuery 写法 $(parent).prepend ($(child)); // DOM 写法 parent.insertBefore (child, parent.childNodes[0]);
删除 DOM 元素。
// jQuery 写法 $(child) .remove (); // DOM 写法 child.parentNode.removeChild (child);
三、事件的监听
jQuery 的 on 方法,完全可以用 addEventListener 模拟。
Element.prototype.on = Element.prototype.addEventListener;
为了使用方便,可以在 NodeList 对象上也部署这个方法。
NodeList.prototype.on = function (event, fn) { []['forEach'].call(this, function (el) { el.on(event, fn); }); return this; };
四、事件的触发
jQuery 的 trigger 方法则需要单独部署,相对复杂一些。
Element.prototype.trigger = function (type, data) {
var event = document.createEvent('HTMLEvents');
event.initEvent(type, true, true); event.data = data || {}; event.eventName = type; event.target = this; this.dispatchEvent(event); return this; };在 NodeList 对象上也部署这个方法。
NodeList.prototype.trigger = function (event) {[]['forEach'].call(this, function (el) {el['trigger'](event); }); return this; };五、document.ready
目前的最佳实践,是将 JavaScript 脚本文件都放在页面底部加载。这样的话,其实 document.ready 方法(jQuery 简写为$(function))已经不必要了,因为等到运行的时候,DOM 对象已经生成了。
六、attr 方法
jQuery 使用 attr 方法,读写网页元素的属性。
$("#picture").attr ("src","http://url/to/image";);DOM 元素允许直接读取属性值,写法要简洁许多。
$("#picture").src = "http://url/to/image";;需要注意,input 元素的 this.value 返回的是输入框中的值,链接元素的 this.href 返回的是绝对 URL。如果需要用到这两个网页元素的属性准确值,可以用 this.getAttribute (‘value’) 和 this.getAttibute (‘href’)。
七、addClass 方法
jQuery 的 addClass 方法,用于为 DOM 元素添加一个 class。
$('body') .addClass ('hasJS');DOM 元素本身有一个可读写的 className 属性,可以用来操作 class。
document.body.className = 'hasJS'; // or document.body.className += ' hasJS';
HTML 5 还提供一个 classList 对象,功能更强大(IE 9 不支持)。
document.body.classList.add ('hasJS'); document.body.classList.remove ('hasJS'); document.body.classList.toggle ('hasJS'); document.body.classList.contains ('hasJS');八、CSS
jQuery 的 css 方法,用来设置网页元素的样式。
$(node).css ("color","red");DOM 元素有一个 style 属性,可以直接操作。
element.style.color = "red"; // or element.style.cssText += 'color:red';九、数据储存
jQuery 对象可以储存数据。
$("body") .data ("foo",52);HTML 5 有一个 dataset 对象,也有类似的功能(IE 10 不支持),不过只能保存字符串。
element.dataset.user = JSON.stringify (user); element.dataset.score = score;
十、Ajax
jQuery 的 Ajax 方法,用于异步操作。
$.ajax({ type: "POST", url: "some.php", data: { name: "John", location: "Boston" } }).done(function( msg ) { alert( "Data Saved: " + msg ); });我们可以定义一个 request 函数,模拟 Ajax 方法。
function request(type, url, opts, callback) { var xhr = new XMLHttpRequest(); if (typeof opts === 'function') { callback = opts; opts = null; }
xhr.open(type, url); var fd = new FormData(); if (type === 'POST' && opts) { for (var key in opts) { fd.append(key, JSON.stringify(opts[key])); } } xhr.onload = function () { callback(JSON.parse(xhr.response)); }; xhr.send(opts ? fd : null); }
然后,基于 request 函数,模拟 jQuery 的 get 和 post 方法。
var get = request.bind (this, 'GET'); var post = request.bind (this, 'POST');