去JQUERY化
时间 2016-05-17 12:43:59 OurJS
原文 http://ourjs.com/detail/573a9cec88feaf2d031d24fc
主题 jQuery
这是一篇使用原生JavaScript代替jQuery实践的文章, GitHub 原文 前端发展很快,现代浏览器原生 API 已经足够好用。我们并不需要为了操作 DOM、Event 等再学习一下 jQuery 的 API。同时由于 React、Angular、Vue 等框架的流行,直接操作 DOM 不再是好的模式,jQuery 使用场景大大减少。本项目总结了大部分 jQuery API 替代的方法,暂时只支持 IE10+ 以上浏览器。 Query Selector 常用的 class、id、属性 选择器都可以使用 document.querySelector 或 document.querySelectorAll 替代。区别是 document.querySelector 返回第一个匹配的 Element
document.querySelectorAll 返回所有匹配的 Element 组成的 NodeList。它可以通过 [].slice.call() 把它转成 Array
如果匹配不到任何 Element,jQuery 返回空数组 [] ,但 document.querySelector 返回 null ,注意空指针异常。当找不到时,也可以使用 || 设置默认的值,如 document.querySelectorAll(selector) || []
注意: document.querySelector 和 document.querySelectorAll 性能很差。如果想提高性能,尽量使用 document.getElementById 、 document.getElementsByClassName 或 document.getElementsByTagName 。 1.0 Query by selector // jQuery
$('selector'); // Native
document.querySelectorAll('selector');
1.1 Query by class // jQuery
$('.css'); // Native
document.querySelectorAll('.css'); // or
document.getElementsByClassName('css');
1.2 Query by id // jQuery
$('#id'); // Native
document.querySelector('#id'); // or
document.getElementById('id');
1.3 Query by attribute // jQuery
$('a[target=_blank]'); // Native
document.querySelectorAll('a[target=_blank]');
1.4 Find sth. Find nodes // jQuery
$el.find('li'); // Native
el.querySelectorAll('li');
Find body // jQuery
$('body'); // Native
document.body;
Find Attribute // jQuery
$el.attr('foo'); // Native
e.getAttribute('foo');
Find data attribute // jQuery
$el.data('foo'); // Native
// using getAttribute
el.getAttribute('data-foo');
// you can also use `dataset` if only need to support IE 11+
el.dataset['foo'];
1.5 Sibling/Previous/Next Elements Sibling elements // jQuery
$el.siblings(); // Native
[].filter.call(el.parentNode.children, function(child) {
return child !== el;
});
Previous elements // jQuery
$el.prev(); // Native
el.previousElementSibling;
Next elements // next
$el.next();
el.nextElementSibling;
1.6 Closest Closest 获得匹配选择器的第一个祖先元素,从当前元素开始沿 DOM 树向上。 // jQuery
$el.closest(queryString); // Native
function closest(el, selector) {
const matchesSelector = el.matches || el.webkitMatchesSelector || el.mozMatchesSelector || el.msMatchesSelector; while (el) {
if (matchesSelector.call(el, selector)) {
return el;
} else {
el = el.parentElement;
}
}
return null;
}
1.7 Parents Until 获取当前每一个匹配元素集的祖先,不包括匹配元素的本身。 // jQuery
$el.parentsUntil(selector, filter); // Native
function parentsUntil(el, selector, filter) {
const result = [];
const matchesSelector = el.matches || el.webkitMatchesSelector || el.mozMatchesSelector || el.msMatchesSelector; // match start from parent
el = el.parentElement;
while (el && !matchesSelector.call(el, selector)) {
if (!filter) {
result.push(el);
} else {
if (matchesSelector.call(el, filter)) {
result.push(el);
}
}
el = el.parentElement;
}
return result;
}
1.8 Form Input/Textarea // jQuery
$('#my-input').val(); // Native
document.querySelector('#my-input').value;
Get index of e.currentTarget between .radio // jQuery
$(e.currentTarget).index('.radio'); // Native
[].indexOf.call(document.querySelectorAll('.radio'), e.currentTarget);
1.9 Iframe Contents jQuery 对象的 iframe contents() 返回的是 iframe 内的 document Iframe contents // jQuery
$iframe.contents(); // Native
iframe.contentDocument;
Iframe Query // jQuery
$iframe.contents().find('.css'); // Native
iframe.contentDocument.querySelectorAll('.css');
CSS & Style 2.1 CSS Get style // jQuery
$el.css("color"); // Native
// 注意:此处为了解决当 style 值为 auto 时,返回 auto 的问题
const win = el.ownerDocument.defaultView;
// null 的意思是不返回伪类元素
win.getComputedStyle(el, null).color;
Set style // jQuery
$el.css({ color: "#ff0011" }); // Native
el.style.color = '#ff0011';
Get/Set Styles 注意,如果想一次设置多个 style,可以参考 oui-dom-utils 中 setStyles 方法 Add class // jQuery
$el.addClass(className); // Native
el.classList.add(className);
Remove class // jQuery
$el.removeClass(className); // Native
el.classList.remove(className);
has class // jQuery
$el.hasClass(className); // Native
el.classList.contains(className);
Toggle class // jQuery
$el.toggleClass(className); // Native
el.classList.toggle(className);
2.2 Width & Height Width 与 Height 获取方法相同,下面以 Height 为例: Window height // jQuery
$(window).height(); // Native
// 不含 scrollbar,与 jQuery 行为一致
window.document.documentElement.clientHeight;
// 含 scrollbar
window.innerHeight;
Document height // jQuery
$(document).height(); // Native
document.documentElement.scrollHeight;
Element height // jQuery
$el.height(); // Native
// 与 jQuery 一致(一直为 content 区域的高度)
function getHeight(el) {
const styles = this.getComputedStyles(el);
const height = el.offsetHeight;
const borderTopWidth = parseFloat(styles.borderTopWidth);
const borderBottomWidth = parseFloat(styles.borderBottomWidth);
const paddingTop = parseFloat(styles.paddingTop);
const paddingBottom = parseFloat(styles.paddingBottom);
return height - borderBottomWidth - borderTopWidth - paddingTop - paddingBottom;
}
// 精确到整数(border-box 时为 height 值,content-box 时为 height + padding + border 值)
el.clientHeight;
// 精确到小数(border-box 时为 height 值,content-box 时为 height + padding + border 值)
el.getBoundingClientRect().height;
Iframe height $iframe .contents() 方法返回 iframe 的 contentDocument // jQuery
$('iframe').contents().height(); // Native
iframe.contentDocument.documentElement.scrollHeight;
2.3 Position & Offset Position // jQuery
$el.position(); // Native
{ left: el.offsetLeft, top: el.offsetTop }
Offset // jQuery
$el.offset(); // Native
function getOffset (el) {
const box = el.getBoundingClientRect(); return {
top: box.top + window.pageYOffset - document.documentElement.clientTop,
left: box.left + window.pageXOffset - document.documentElement.clientLeft
}
}
2.4 Scroll Top // jQuery
$(window).scrollTop(); // Native
(document.documentElement && document.documentElement.scrollTop) || document.body.scrollTop;
DOM Manipulation 3.1 Remove // jQuery
$el.remove(); // Native
el.parentNode.removeChild(el);
3.2 Text Get text // jQuery
$el.text(); // Native
el.textContent;
Set text // jQuery
$el.text(string); // Native
el.textContent = string;
3.3 HTML Get HTML // jQuery
$el.html(); // Native
el.innerHTML;
Set HTML // jQuery
$el.html(htmlString); // Native
el.innerHTML = htmlString;
3.4 Append Append 插入到子节点的末尾 // jQuery
$el.append("<div id='container'>hello</div>"); // Native
let newEl = document.createElement('div');
newEl.setAttribute('id', 'container');
newEl.innerHTML = 'hello';
el.appendChild(newEl);
3.5 Prepend // jQuery
$el.prepend("<div id='container'>hello</div>"); // Native
let newEl = document.createElement('div');
newEl.setAttribute('id', 'container');
newEl.innerHTML = 'hello';
el.insertBefore(newEl, el.firstChild);
3.6 insertBefore 在选中元素前插入新节点 // jQuery
$newEl.insertBefore(queryString); // Native
const target = document.querySelector(queryString);
target.parentNode.insertBefore(newEl, target);
3.7 insertAfter 在选中元素后插入新节点 // jQuery
$newEl.insertAfter(queryString); // Native
const target = document.querySelector(queryString);
target.parentNode.insertBefore(newEl, target.nextSibling);
Ajax 用 fetch 和 fetch-jsonp 替代 Events 完整地替代命名空间和事件代理,链接到 https://github.com/oneuijs/oui-dom-events 5.1 Bind an event with on // jQuery
$el.on(eventName, eventHandler); // Native
el.addEventListener(eventName, eventHandler);
5.2 Unbind an event with off // jQuery
$el.off(eventName, eventHandler); // Native
el.removeEventListener(eventName, eventHandler);
5.3 Trigger // jQuery
$(el).trigger('custom-event', {key1: 'data'}); // Native
if (window.CustomEvent) {
const event = new CustomEvent('custom-event', {detail: {key1: 'data'}});
} else {
const event = document.createEvent('CustomEvent');
event.initCustomEvent('custom-event', true, true, {key1: 'data'});
} el.dispatchEvent(event);
Utilities 6.1 isArray // jQuery
$.isArray(range); // Native
Array.isArray(range);
6.2 Trim // jQuery
$.trim(string); // Native
string.trim();
6.3 Object Assign 继承,使用 object.assign polyfill https://github.com/ljharb/object.assign // jQuery
$.extend({}, defaultOpts, opts); // Native
Object.assign({}, defaultOpts, opts);
6.4 Contains // jQuery
$.contains(el, child); // Native
el !== child && el.contains(child);
Alternatives 你可能不需要 jQuery (You Might Not Need jQuery) - 如何使用原生 JavaScript 实现通用事件,元素,ajax 等用法。
npm-dom 以及 webmodules - 在 NPM 上提供独立 DOM 模块的组织
Browser Support
Latest ✔ Latest ✔ 10+ ✔ Latest ✔ 6.1+ ✔
去JQUERY化的更多相关文章
- IM 去中心化概念模型与架构设计
今天打算写写关于 IM 去中心化涉及的架构模型变化和设计思路,去中心化的概念就是说用户的访问不是集中在一个数据中心,这里的去中心是针对数据中心而言的. 站在这个角度而言,实际上并非所有的业务都能做去中 ...
- 小众Tox——大众的“去中心化”聊天软件
★Tox是什么 一个反窥探的开源项目:一种基于DHT(BitTorrent)技术的即时通讯协议:一个为安全而生的加密通讯系统 .美国棱镜计划曝光后,一个名为 irungentoo 的牛人于17天后的2 ...
- 基于Twitter-Snowflake的java改进版,去状态化实现
package jeffery; import java.net.InetAddress; import java.net.UnknownHostException; import java.util ...
- FineUI大版本升级,外置ExtJS库、去AXD化、表格合计行、表格可编辑单元格的增删改、顶部菜单框架
这是一篇很长的文章,在开始正文之前,请允许我代表目前排名前 20 中唯一的 .Net 开源软件 FineUI 拉下选票: 投票地址: https://code.csdn.net/2013OSSurve ...
- 去model化开发
前言 去model化是一种框架设计上的做法,其中的model并不是指架构中的model层,套用Casa大神博客中的原文就是: model化就是使用数据对象,去model化就是不使用数据对象. 常见的去 ...
- 一个轻client,多语言支持,去中心化,自己主动负载,可扩展的实时数据写服务的实现方案讨论
背景 背景是设计一个实时数据接入的模块,负责接收client的实时数据写入(如日志流,点击流),数据支持直接下沉到HBase上(兴许提供HBase上的查询),或先持久化到Kafka里.方便兴许进行一些 ...
- 一步步教你开发、部署第一个去中心化应用(Dapp) - 宠物商店
今天我们来编写一个完整的去中心化(区块链)应用(Dapps), 本文可以和编写智能合约结合起来看. 写在前面 阅读本文前,你应该对以太坊.智能合约有所了解,如果你还不了解,建议你先看以太坊是什么除此之 ...
- ImCash:币安下架BSV之辩:规则、中立与去中心化
一种看法是:一个引用价格数据和执行交易的加密货币交易所,其业务决策往往是在链外发生的,不受制于严格的.类似于准宪法的链上规则的约束,加密货币交易所可以拒绝任何人喜欢的价格和交易,而且这样做并不会损害底 ...
- 理解去中心化 稳定币 DAI
本文转载于深入浅出区块链, 原文链接 随着摩根大通推出JPM Coin 稳定币,可以预见稳定币将成为区块链落地的一大助推器. 坦白来讲,对于一个程序员的我来讲(不懂一点专业经济和金融),理解DAI的机 ...
随机推荐
- Linux系统性能测试工具(一)——内存带宽测试工具mbw
本文介绍关于Linux系统(适用于centos/ubuntu等)的内存带宽测试工具-mbw.内存性能测试工具包括: 内存带宽测试工具——mbw: 内存压力测试工具——memtester: 内存综合性能 ...
- OGG replicat复制进程的拆分
参考资料: 1.https://blog.csdn.net/datingting1/article/details/79583690
- Reference与ReferenceQueue
Reference源码分析 首先我们先看一下Reference类的注释: /** * Abstract base class for reference objects. This class def ...
- alert(1) to win 2
function escape(s) { s = s.replace(/"/g, '\\"'); return '<script>console.log("' ...
- Windows电脑无法识别USB设备怎么办?
您可能已经注意到,如果您使用USB设备并将其插入计算机,Windows会识别并配置它.然后,如果你拔掉它并将其重新插入另一个USB端口,Windows就会出现一连串的健忘症,并认为这是一个完全不同的设 ...
- django之创建项目
1.创建虚拟环境 mkvirtualenv django_study -p python3 创建成功后:(django_study) python@ubuntu:~$ 2.安装django-指定版本1 ...
- hdu 6127 : Hard challenge (2017 多校第七场 1008)(计算几何)
题目链接 题意:二维平面上有n个点(没有重叠,都不在原点,任意两点连线不过原点),每个点有一个权值,用一条过原点的直线把他们划分成两部分,使两部分的权值和的乘积最大.输出最大的乘积. 极角排序后,将原 ...
- Bugku 杂项 签到题
签到题 加微信公众号会发现
- 【转】Django-template模板语言
Django-template模板语言 转自:https://www.cnblogs.com/zzy-9318/p/8672945.html 一.常用语法 只需要记两种特殊符号: {{ }}和 {% ...
- Windowed functions can only appear in the SELECT or ORDER BY clauses
尝试做分页处理 select row_number over (orderby id asc) as rownum,* from table where rownum>=(@page*@page ...