前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >jQuery VS JavaScript原生API

jQuery VS JavaScript原生API

作者头像
晚晴幽草轩轩主
发布2018-03-27 16:25:57
1.6K0
发布2018-03-27 16:25:57
举报
文章被收录于专栏:静晴轩

如今技术日新月异,各类框架库也是层次不穷。即便当年漫山红遍的JQuery(让开发者write less, do more,So Perfect!!)如今也有被替代的大势。但JS原生API写法依旧;并且有时候只不过小写一个Demo,或者产品中只有少量的前端效果或DOM操作,就去花时间&空间引入jQuery,或者React?不免有取宰牛之刀以杀鸡之嫌。

在jQuery的温柔乡里,是否还能记得原生她javascript原生?如果仅为使用个选择器($)或者类似的东西,是否真的有必要加载jQuery?故此了解下JS常用原生写法还是蛮有必要的。

[update-2015-12-07]有看到抛弃jQuery,拥抱原生JavaScript一文中提到,jQuery 代表着传统的以 DOM 为中心的开发模式,但现在复杂页面开发流行的是以 React 为代表的以数据/状态为中心的开发模式; React、Angular、Vue 等框架的流行,直接操作 DOM 不再是好的模式,jQuery 使用场景大大减少。

Talk is cheap. Show me the code.直接看代码;以下是jQuery和JavaScript实现相同操作的等价代码:

选择元素

代码语言:javascript
复制
// jQuery  
var els = $('.el');  

//==========================================================//
// 原生方法  
var els = document.querySelectorAll('.el');  

// 函数法  
var $ = function (el) {  
  return document.querySelectorAll(el);  
}  
var els = $('.el');

创建元素

代码语言:javascript
复制
// jQuery  
var newEl = $('<div/>');  

//==========================================================//
// 原生方法  
var newEl = document.createElement('div');

添加/移除/切换类

代码语言:javascript
复制
// jQuery  
$('.el').addClass('class');  
$('.el').removeClass('class');  
$('.el').toggleClass('class');  

//==========================================================//
// 原生方法  
document.querySelector('.el').classList.add('class');  
document.querySelector('.el').classList.remove('class');
document.querySelector('.el').classList.toggle('class');

判断是否包含类

代码语言:javascript
复制
// jQuery
$('.el').hasClass('className');
$('.el').has('.className'); //也可以用来 判断是否包含某个元素

//==========================================================//
// 原生方法(1)
_hasClass(document.querySelector('.el'), className);
function _hasClass( elements,cName ){
    return !!elements.className.match( new RegExp( "(\\s|^)" + cName + "(\\s|$)") );
};

// 原生方法(2)
if(el.classList.contains("someClass")){}

添加事件监听器

代码语言:javascript
复制
// jQuery  
$('.el').on('event', function() {
});  

//==========================================================//  
// 原生方法  
[].forEach.call(document.querySelectorAll('.el'), function (el) {  
  el.addEventListener('event', function() {
  }, false);
});

原生-DOM绑定事件-优化1参考HERE

代码语言:javascript
复制
//DOM绑定事件-之自执行
var BindEvent = (function () {
  if ('addEventListener' in document) {
    return function (dom, event, handle, ex) {
      dom.addEventListener(event, handle, ex || false);
    }
  } else if ('attachEvent' in document) {
    return function (dom, event, handle) {
      dom.attachEvent('on' + event, handle);
    }
  } else {
    return function (dom, event, handle) {
      dom['on' + event] = handle;
    }
  }
})();

原生-DOM绑定事件-优化2

代码语言:javascript
复制
//DOM绑定事件-之惰性加载(调用方去触发BindEvent之时才去做初始化)//
var BindEvent = function (dom, event, handle, ex) {
  if ('addEventListener' in document) {
    BindEvent = function (dom, event, handle, ex) {
      dom.addEventListener(event, handle, ex || false);
    }
  } else if ('attachEvent' in document) {
trueBindEvent = function (dom, event, handle) {
      dom.attachEvent('on' + event, handle);
    }
  } else {
    BindEvent = function (dom, event, handle) {
      dom['on' + event] = handle;
    }
  }
  BindEvent(dom, event, handle, ex);
};

设置/获取属性

代码语言:javascript
复制
// jQuery  
$('.el').filter(':first').attr('key', 'value');  
$('.el').filter(':first').attr('key');  

//==========================================================//
// 原生方法  
document.querySelector('.el').setAttribute('key', 'value');  
document.querySelector('.el').getAttribute('key');

附加内容(Append)

代码语言:javascript
复制
// jQuery  
$('.el').append($('<div/>'));  

//==========================================================//
// 原生方法  
document.querySelector('.el').appendChild(document.createElement('div'));

克隆元素

代码语言:javascript
复制
// jQuery  
var clonedEl = $('.el').clone();  

//==========================================================//
// 原生方法  
var clonedEl = document.querySelector('.el').cloneNode(true);

移除元素

代码语言:javascript
复制
// jQuery  
$('.el').remove();  

//==========================================================//
// 原生方法  
remove('.el');  
function remove(el) {  
  var toRemove = document.querySelector(el);  
  toRemove.parentNode.removeChild(toRemove);  
}

获取父元素

代码语言:javascript
复制
// jQuery  
$('.el').parent();  

//==========================================================//
// 原生方法  
document.querySelector('.el').parentNode;

上一个/下一个元素

代码语言:javascript
复制
// jQuery  
$('.el').prev();  
$('.el').next();  

//==========================================================//
// 原生方法  
document.querySelector('.el').previousElementSibling;  
document.querySelector('.el').nextElementSibling;

修改CSS属性

总是通过Javascript修改和检索CSS属性,这样会比使用jQuery CSS函数更加简单快速,并且没有任何不必要的代码。

代码语言:javascript
复制
 //----设置CSS属性----

/* jQuery */
  $(el).css({
    background: "#FF0000",
"box-shadow": "1px 1px 5px 5px red",
    width: "100px",
    height: "100px",
    display: "block"
  });

//==========================================================//
/* 原生 */
var el = document.querySelector(".main-content");
el.style.background = "#FF0000";
el.style.width = "100px";
el.style.height = "100px";
el.style.display = "block";
el.style.boxShadow = "1px 1px 5px 5px red";

XHR或AJAX

代码语言:javascript
复制
// jQuery  
$.get('url', function (data) {  

});  
$.post('url', {data: data}, function (data) {  

});  

//==========================================================//
// 原生方法  
// 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});

参考文章:http://www.iteye.com/news/28503 英文原文:http://blog.romanliutikov.com/post/63383858003/how-to-forget-about-jquery-and-start-using-native

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2015-11-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 选择元素
  • 创建元素
  • 添加/移除/切换类
  • 判断是否包含类
  • 添加事件监听器
  • 设置/获取属性
  • 附加内容(Append)
  • 克隆元素
  • 移除元素
  • 获取父元素
  • 上一个/下一个元素
  • 修改CSS属性
  • XHR或AJAX
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档