JavaScript原生API

简介: JavaScript原生API

jQuery目前已经成为最流行的JavaScript库,它可以让开发者“write less, do more(写得更少,做得更多)”,这也是它的核心理念。通过它,用户可以更方便地处理HTML documents、events,更轻松地实现动画效果、AJAX交互等。


尽管jQuery帮助开发者节省了大量的工作,但是并不是所有的产品都适合使用jQuery。jQuery 2.0.3版本有236KB,压缩版也有81KB,这意味着你的Web产品需要额外的加载时间和带宽,而在移动设备上则需要更多。

如果你的产品中只有少量的前端效果或DOM操作,那么完全可以抛弃臃肿的jQuery,转而使用JavaScript原生API来实现。

以下是jQuery和JavaScript实现相同操作的等价代码。


选择元素 

Javascript代码

// jQuery  
var els = $('.el');  
// 原生方法  
var els = document.querySelectorAll('.el');  
// 函数法  
var $ = function (el) {  
  return document.querySelectorAll(el);  
}  
var els = $('.el');  
// 或者使用regex-based micro-selector库,地址:http://jsperf.com/micro-selector-libraries

 

创建元素 


Javascript代码

1. // jQuery  
2. var newEl = $('<div/>');  
3.   
4. // 原生方法  
5. var newEl = document.createElement('div');

添加事件监听器 


Javascript代码

1. // jQuery  
2. $('.el').on('event', function() {  
3.   
4. });  
5.   
6. // 原生方法  
7. [].forEach.call(document.querySelectorAll('.el'), function (el) {  
8.   el.addEventListener('event', function() {  
9.   
10.   }, false);  
11. });

设置/获取属性 


Javascript代码

1. // jQuery  
2. $('.el').filter(':first').attr('key', 'value');  
3. $('.el').filter(':first').attr('key');  
4.   
5. // 原生方法  
6. document.querySelector('.el').setAttribute('key', 'value');  
7. document.querySelector('.el').getAttribute('key');


添加/移除/切换类 


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');


附加内容(Append) 


Javascript代码

// jQuery  
$('.el').append($('<div/>'));  
// 原生方法  
document.querySelector('.el').appendChild(document.createElement('div'));


克隆元素 


Javascript代码

1. // jQuery  
2. var clonedEl = $('.el').clone();  
3.   
4. // 原生方法  
5. var clonedEl = document.querySelector('.el').cloneNode(true);


移除元素 


Javascript代码

1. // jQuery  
2. $('.el').remove();  
3.   
4. // 原生方法  
5. remove('.el');  
6.   
7. function remove(el) {  
8.   var toRemove = document.querySelector(el);  
9.   
10.   toRemove.parentNode.removeChild(toRemove);  
11. }

获取父元素 


Javascript代码

// jQuery  
$('.el').parent();  
// 原生方法  
document.querySelector('.el').parentNode;


上一个/下一个元素 


Javascript代码

// jQuery  
$('.el').prev();  
$('.el').next();  
// 原生方法  
document.querySelector('.el').previousElementSibling;  
document.querySelector('.el').nextElementSibling;


XHR或AJAX 


Javascript代码

1. // jQuery  
2. $.get('url', function (data) {  
3.   
4. });  
5. $.post('url', {data: data}, function (data) {  
6.   
7. });  
8.   
9. // 原生方法  
10. // get  
11. var xhr = new XMLHttpRequest();  
12.   
13. xhr.open('GET', url);  
14. xhr.onreadystatechange = function (data) {  
15.   
16. }  
17. xhr.send();  
18.   
19. // post  
20. var xhr = new XMLHttpRequest()  
21.   
22. xhr.open('POST', url);  
23. xhr.onreadystatechange = function (data) {  
24.   
25. }  
26. xhr.send({data: data});

你也可以使用其他非常轻量级的库代替,比如http://microjs.com/列出的一些库,根据你的需求选择最合适的库,但首先要清楚,除非是不使用库无法实现某项功能,否则还是使用原生JavaScript。


目录
相关文章
|
9月前
|
前端开发 JavaScript NoSQL
使用 Node.js、Express 和 React 构建强大的 API
本文详细介绍如何使用 Node.js、Express 和 React 构建强大且动态的 API。从开发环境搭建到集成 React 前端,再到利用 APIPost 高效测试 API,适合各水平开发者。内容涵盖 Node.js 运行时、Express 框架与 React 库的基础知识及协同工作方式,还涉及数据库连接和前后端数据交互。通过实际代码示例,助你快速上手并优化应用性能。
|
9月前
|
数据采集 搜索推荐 API
Python 原生爬虫教程:京东商品列表页面数据API
京东商品列表API是电商大数据分析的重要工具,支持开发者、商家和研究人员获取京东平台商品数据。通过关键词搜索、分类筛选、价格区间等条件,可返回多维度商品信息(如名称、价格、销量等),适用于市场调研与推荐系统开发。本文介绍其功能并提供Python请求示例。接口采用HTTP GET/POST方式,支持分页、排序等功能,满足多样化数据需求。
|
JavaScript 前端开发 API
Vue.js 3:探索组合式API带来的新变革
Vue.js 3:探索组合式API带来的新变革
405 84
|
10月前
|
JavaScript 前端开发 API
JavaScript中通过array.map()实现数据转换、创建派生数组、异步数据流处理、复杂API请求、DOM操作、搜索和过滤等,array.map()的使用详解(附实际应用代码)
array.map()可以用来数据转换、创建派生数组、应用函数、链式调用、异步数据流处理、复杂API请求梳理、提供DOM操作、用来搜索和过滤等,比for好用太多了,主要是写法简单,并且非常直观,并且能提升代码的可读性,也就提升了Long Term代码的可维护性。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
9月前
|
数据采集 API 数据格式
Python 原生爬虫教程:京东商品详情页面数据API
本文介绍京东商品详情API在电商领域的应用价值及功能。该API通过商品ID获取详细信息,如基本信息、价格、库存、描述和用户评价等,支持HTTP请求(GET/POST),返回JSON或XML格式数据。对于商家优化策略、开发者构建应用(如比价网站)以及消费者快速了解商品均有重要意义。研究此API有助于推动电商业务创新与发展。
|
JSON 缓存 JavaScript
深入浅出:使用Node.js构建RESTful API
在这个数字时代,API已成为软件开发的基石之一。本文旨在引导初学者通过Node.js和Express框架快速搭建一个功能完备的RESTful API。我们将从零开始,逐步深入,不仅涉及代码编写,还包括设计原则、最佳实践及调试技巧。无论你是初探后端开发,还是希望扩展你的技术栈,这篇文章都将是你的理想指南。
|
12月前
|
JavaScript 前端开发 安全
盘点原生JS中目前最没用的几个功能API
在JavaScript的发展历程中,许多功能与API曾风光无限,但随着技术进步和语言演化,部分功能逐渐被淘汰或被更高效的替代方案取代。例如,`with`语句使代码作用域复杂、可读性差;`void`操作符功能冗余且影响可读性;`eval`函数存在严重安全风险和性能问题;`unescape`和`escape`函数已被`decodeURIComponent`和`encodeURIComponent`取代;`arguments`对象则被ES6的剩余参数语法替代。这些变化体现了JavaScript不断优化的趋势,开发者应紧跟技术步伐,学习新技能,适应新技术环境。
230 10
|
12月前
|
JavaScript 前端开发 测试技术
盘点原生JavaScript中直接触发事件的方式
本文全面探讨了原生JavaScript中触发事件的多种方式,包括`dispatchEvent`、`Event`构造函数、`CustomEvent`构造器、直接调用事件处理器以及过时的`createEvent`和`initEvent`方法。通过技术案例分析,如模拟点击事件、派发自定义数据加载事件和实现提示框系统,帮助开发者掌握这些方法在实际开发中的应用,提升灵活性与兼容性。
455 3
|
JSON JavaScript 前端开发
深入浅出Node.js:从零开始构建RESTful API
在数字化时代的浪潮中,后端开发作为连接用户与数据的桥梁,扮演着至关重要的角色。本文将引导您步入Node.js的奇妙世界,通过实践操作,掌握如何使用这一强大的JavaScript运行时环境构建高效、可扩展的RESTful API。我们将一同探索Express框架的使用,学习如何设计API端点,处理数据请求,并实现身份验证机制,最终部署我们的成果到云服务器上。无论您是初学者还是有一定基础的开发者,这篇文章都将为您打开一扇通往后端开发深层知识的大门。
314 12
|
JavaScript 前端开发 API
Vue.js 3:深入探索组合式API的实践与应用
Vue.js 3:深入探索组合式API的实践与应用