网站如何做到完全不需要 jQuery ?
来源:互联网 发布:厦门住宿推荐 知乎 编辑:程序博客网 时间:2024/04/30 16:42
jQuery 是现在最流行的 JavaScript 工具库。
据统计,目前全世界 57.3% 的网站使用它。也就是说,10 个网站里面,有 6 个使用 jQuery。如果只考察使用工具库的网站,这个比例就会上升到惊人的 91.7%。
虽然 jQuery 如此受欢迎,但是它臃肿的体积也让人头痛不已。jQuery 2.0 的原始大小为 235KB,优化后为 81KB;如果是支持 IE6、7、8 的 jQuery 1.8.3,原始大小为 261KB,优化后为 91KB。
这样的体积,即使是宽带环境,完全加载也需要 1 秒或更长,更不要说移动设备了。这意味着,如果你使用了 jQuery,用户至少延迟 1 秒,才能看到网页效果。考虑到本质上,jQuery 只是一个操作 DOM 的工具,我们不仅要问:如果只是为了几个网页特效,是否有必要动用这么大的库?
2006 年,jQuery 诞生的时候,主要用于消除不同浏览器的差异(主要是 IE6),为开发者提供一个简洁的统一接口。相比当时,如今的情况已经发生了很大的变化。IE 的市场份额不断下降,以 ECMAScript 为基础的 JavaScript 标准语法,正得到越来越广泛的支持。开发者直接使用 JavScript 标准语法,就能同时在各大浏览器运行,不再需要通过 jQuery 获取兼容性。
下面就探讨如何用 JavaScript 标准语法,取代 jQuery 的一些主要功能,做到 jQuery-free。
一、选取 DOM 元素
jQuery 的核心是通过各种选择器,选中 DOM 元素,可以用 querySelectorAll 方法模拟这个功能。
1
var
$ = document.querySelectorAll.bind (document);
这里需要注意的是,querySelectorAll 方法返回的是 NodeList 对象,它很像数组(有数字索引和 length 属性),但不是数组,不能使用 pop、push 等数组特有方法。如果有需要,可以考虑将 Nodelist 对象转为数组。
1
myList = Array.prototype.slice.call (myNodeList);
二、DOM 操作
DOM 本身就具有很丰富的操作方法,可以取代 jQuery 提供的操作方法。
尾部追加 DOM 元素。
1
// jQuery 写法
2
$(parent) .append ($(child));
3
// DOM 写法
4
parent.appendChild (child)
头部插入 DOM 元素。
1
// jQuery 写法
2
$(parent) .prepend ($(child));
3
// DOM 写法
4
parent.insertBefore (child, parent.childNodes[0])
删除 DOM 元素。
1
// jQuery 写法
2
$(child) .remove ()
3
// DOM 写法
4
child.parentNode.removeChild (child)
三、事件的监听
jQuery 的 on 方法,完全可以用 addEventListener 模拟。
1
Element.prototype.on = Element.prototype.addEventListener;
为了使用方便,可以在 NodeList 对象上也部署这个方法。
1
NodeList.prototype.on =
function
(event, fn) {
2
[][
'forEach'
].call (
this
,
function
(el) {
3
el.on (event, fn);
4
});
5
return
this
;
6
};
四、事件的触发
jQuery 的 trigger 方法则需要单独部署,相对复杂一些。
1
Element.prototype.trigger =
function
(type, data) {
2
var
event = document.createEvent (
'HTMLEvents'
);
3
event.initEvent (type,
true
,
true
);
4
event.data = data {};
5
event.eventName = type;
6
event.target =
this
;
7
this
.dispatchEvent (event);
8
return
this
;
9
};
在NodeList对象上也部署这个方法。
1
NodeList.prototype.trigger =
function
(event) {
2
[][
'forEach'
].call (
this
,
function
(el) {
3
el[
'trigger'
](event);
4
});
5
return
this
;
6
};
五、document.ready
目前的最佳实践,是将 JavaScript 脚本文件都放在页面底部加载。这样的话,其实 document.ready 方法(jQuery 简写为$(function))已经不必要了,因为等到运行的时候,DOM 对象已经生成了。
六、attr 方法
jQuery 使用 attr 方法,读写网页元素的属性。
1
$(
"#picture"
) .attr (
"src"
,
"http://url/to/image"
);
DOM 元素允许直接读取属性值,写法要简洁许多。
1
$(
"#picture"
) .src =
"http://url/to/image"
;
需要注意,input 元素的 this.value 返回的是输入框中的值,链接元素的 this.href 返回的是绝对 URL。如果需要用到这两个网页元素的属性准确值,可以用 this.getAttribute (‘value’)和 this.getAttibute (‘href’)。
七、addClass 方法
jQuery 的 addClass 方法,用于为 DOM 元素添加一个 class。
1
$(
'body'
) .addClass (
'hasJS'
);
DOM 元素本身有一个可读写的 className 属性,可以用来操作 class。
1
document.body.className =
'hasJS'
;
2
// or
3
document.body.className +=
' hasJS'
;
HTML 5 还提供一个 classList 对象,功能更强大(IE 9 不支持)。
1
document.body.classList.add (
'hasJS'
);
2
document.body.classList.remove (
'hasJS'
);
3
document.body.classList.toggle (
'hasJS'
);
4
document.body.classList.contains (
'hasJS'
);
八、CSS
jQuery 的 css 方法,用来设置网页元素的样式。
1
$(node) .css (
"color"
,
"red"
);
DOM 元素有一个 style 属性,可以直接操作。
1
element.style.color =
"red"
;;
2
// or
3
element.style.cssText +=
'color:red'
;
九、数据储存
jQuery 对象可以储存数据。
1
$(
"body"
) .data (
"foo"
, 52);
HTML 5 有一个 dataset 对象,也有类似的功能(IE 10 不支持),不过只能保存字符串。
1
element.dataset.user = JSON.stringify (user);
2
element.dataset.score = score;
十、Ajax
jQuery 的 Ajax 方法,用于异步操作。
1
$.ajax ({
2
type:
"POST"
,
3
url:
"some.php"
,
4
data: { name:
"John"
, location:
"Boston"
}
5
}) .done (
function
( msg ) {
6
alert (
"Data Saved: "
+ msg );
7
});
我们可以定义一个 request 函数,模拟 Ajax 方法。
01
function
request (type, url, opts, callback) {
02
var
xhr =
new
XMLHttpRequest ();
03
if
(
typeof
opts ===
'function'
) {
04
callback = opts;
05
opts =
null
;
06
}
07
xhr.open (type, url);
08
var
fd =
new
FormData ();
09
if
(type ===
'POST'
&& opts) {
10
for
(
var
key
in
opts) {
11
fd.append (key, JSON.stringify (opts[key]));
12
}
13
}
14
xhr.onload =
function
() {
15
callback (JSON.parse (xhr.response));
16
};
17
xhr.send (opts ? fd :
null
);
18
}
然后,基于 request 函数,模拟 jQuery 的 get 和 post 方法。
1
var
get = request.bind (
this
,
'GET'
);
2
var
post = request.bind (
this
,
'POST'
);
十一、动画
jQuery 的 animate 方法,用于生成动画效果。
1
$foo.animate (
'slow'
, { x:
'+=10px'
});
jQuery 的动画效果,很大部分基于 DOM。但是目前,CSS 3 的动画远比 DOM 强大,所以可以把动画效果写进 CSS,然后通过操作 DOM 元素的 class,来展示动画。
1
foo.classList.add (
'animate'
);
如果需要对动画使用回调函数,CSS 3 也定义了相应的事件。
1
el.addEventListener (
"webkitTransitionEnd"
, transitionEnded);
2
el.addEventListener (
"transitionend"
, transitionEnded);
十二、替代方案
由于 jQuery 体积过大,替代方案层出不穷。
其中,最有名的是 zepto.js。它的设计目标是以最小的体积,做到最大兼容 jQuery 的 API。zepto.js 1.0 版的原始大小是 55KB,优化后是 29KB,gzip 压缩后为 10KB。
如果不求最大兼容,只希望模拟 jQuery 的基本功能,那么,min.js 优化后只有 200 字节,而 dolla 优化后是 1.7KB。
此外,jQuery 本身采用模块设计,可以只选择使用自己需要的模块。具体做法参见它的 GitHub 网站,或者使用专用的 Web 界面。
十三、参考链接
- Remy Sharp,I know jQuery. Now what?
- Hemanth.HM,Power of Vanilla JS
- Burke Holland,5 Things You Should Stop Doing With jQuery
(完)
- 网站如何做到完全不需要 jQuery ?
- 网站如何做到完全不需要jQuery
- 网站如何做到完全不需要 jQuery ?
- 网站如何做到 jQuery-free?
- 如何做到 jQuery-free?
- 如何做到 jQuery-free?
- 如何做到 jQuery-free?
- 如何做到 jQuery-free?
- 如何做到 jQuery-free?
- 网站推广如何做到保质保量?
- 如何做到网站改版不换权
- android 如何做到完全退出应用程序
- 如何只用CSS做到完全居中
- 如何只用 CSS 做到完全居中
- 如何只用CSS做到完全居中
- 如何只用CSS做到完全居中
- 如何只用CSS做到完全居中
- 如何只用CSS做到完全居中
- js - 关于部分浏览器内置函数console详解(用开发调试的利器)
- add_months 和interval 的区别
- android智能机低电关机后关机闹钟不响的原因及解决方案
- 关于jquery dialog被activeX插件遮挡问题的解决办法
- 支你两小招让你的电脑蜗牛变飞机
- 网站如何做到完全不需要 jQuery ?
- 完全实现路由器实现无线化有可能吗
- qt-4.7.2的arm版本安装方法
- ICON
- Apache Solr 初级教程
- [LeeCode]Search for a Range, 解题报告
- Ubuntu上离线安装包的制作与安装
- C# DataTable 过滤重复数据
- 【Android】Google坐标到百度地图坐标转换