时间 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化的更多相关文章

  1. IM 去中心化概念模型与架构设计

    今天打算写写关于 IM 去中心化涉及的架构模型变化和设计思路,去中心化的概念就是说用户的访问不是集中在一个数据中心,这里的去中心是针对数据中心而言的. 站在这个角度而言,实际上并非所有的业务都能做去中 ...

  2. 小众Tox——大众的“去中心化”聊天软件

    ★Tox是什么 一个反窥探的开源项目:一种基于DHT(BitTorrent)技术的即时通讯协议:一个为安全而生的加密通讯系统 .美国棱镜计划曝光后,一个名为 irungentoo 的牛人于17天后的2 ...

  3. 基于Twitter-Snowflake的java改进版,去状态化实现

    package jeffery; import java.net.InetAddress; import java.net.UnknownHostException; import java.util ...

  4. FineUI大版本升级,外置ExtJS库、去AXD化、表格合计行、表格可编辑单元格的增删改、顶部菜单框架

    这是一篇很长的文章,在开始正文之前,请允许我代表目前排名前 20 中唯一的 .Net 开源软件 FineUI 拉下选票: 投票地址: https://code.csdn.net/2013OSSurve ...

  5. 去model化开发

    前言 去model化是一种框架设计上的做法,其中的model并不是指架构中的model层,套用Casa大神博客中的原文就是: model化就是使用数据对象,去model化就是不使用数据对象. 常见的去 ...

  6. 一个轻client,多语言支持,去中心化,自己主动负载,可扩展的实时数据写服务的实现方案讨论

    背景 背景是设计一个实时数据接入的模块,负责接收client的实时数据写入(如日志流,点击流),数据支持直接下沉到HBase上(兴许提供HBase上的查询),或先持久化到Kafka里.方便兴许进行一些 ...

  7. 一步步教你开发、部署第一个去中心化应用(Dapp) - 宠物商店

    今天我们来编写一个完整的去中心化(区块链)应用(Dapps), 本文可以和编写智能合约结合起来看. 写在前面 阅读本文前,你应该对以太坊.智能合约有所了解,如果你还不了解,建议你先看以太坊是什么除此之 ...

  8. ImCash:币安下架BSV之辩:规则、中立与去中心化

    一种看法是:一个引用价格数据和执行交易的加密货币交易所,其业务决策往往是在链外发生的,不受制于严格的.类似于准宪法的链上规则的约束,加密货币交易所可以拒绝任何人喜欢的价格和交易,而且这样做并不会损害底 ...

  9. 理解去中心化 稳定币 DAI

    本文转载于深入浅出区块链, 原文链接 随着摩根大通推出JPM Coin 稳定币,可以预见稳定币将成为区块链落地的一大助推器. 坦白来讲,对于一个程序员的我来讲(不懂一点专业经济和金融),理解DAI的机 ...

随机推荐

  1. Git基本常用指令

    开发十年,就只剩下这套架构体系了! >>>   Git基本常用命令如下: mkdir:         XX (创建一个空目录 XX指目录名) pwd:          显示当前目 ...

  2. Linux awk抓取IP的两种方式

    ip addr show ens33 | awk -F "[ /]+" '/inet /{print $3}' 或 ifconfig ens33 | awk -F "[ ...

  3. Ubuntu Anaconda3 环境下安装caffe

    安装Python环境 本人环境为Anaconda3 ,可参照 https://blog.csdn.net/ctwy291314/article/details/86571198 完成安装Python2 ...

  4. nodejs http服务器简单搭建

    var http = require('http') // 1. 创建 Server var server = http.createServer() // 2. 监听 request 请求事件,设置 ...

  5. [NOIP2009]最优贸易(图论)

    [NOIP2009]最优贸易 题目描述 CC 国有 \(n\) 个大城市和 \(m\) 条道路,每条道路连接这 \(n\) 个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这 \(m\ ...

  6. 12 | 为什么我的MySQL会“抖”一下? 学习记录

    <MySQL实战45讲>12 | 为什么我的MySQL会“抖”一下? 学习记录 http://naotu.baidu.com/file/15aa54cab2fa882c6a2a1dd52e ...

  7. LeetCode--050--Pow(x,n)

    实现 pow(x, n) ,即计算 x 的 n 次幂函数. 示例 1: 输入: 2.00000, 10 输出: 1024.00000 示例 2: 输入: 2.10000, 3 输出: 9.26100 ...

  8. python-数据驱动

    1.parameterized.parameterized import unittest from parameterized import parameterized,param class Te ...

  9. python学习笔记(六)函数

    1.函数是什么? 定义:函数是指一组语句的集合通过一个名字(函数名)封装起来,只需调用函数名即可. 2.函数的好处: 简化代码 提高代码的复用性 代码可扩展 3.python中函数的定义: 定义函数使 ...

  10. oracle比较两个库同表栏目差异

    select T.COLUMN_NAME,t.data_type ,c.comments from ALL_TAB_COLUMNS T ,user_col_comments c and c.table ...