博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
你不需要jQuery(五)
阅读量:5893 次
发布时间:2019-06-19

本文共 2489 字,大约阅读时间需要 8 分钟。

什么不用jQuery?因为它让你的网站体积变得臃肿。你的网站并不真的需要jQuery,不需要它带来的额外体积、带宽和加载时间。

用原生JavaScript简单实现jQuery提供的功能和方法

查找、选择页面元素

// jQuery 实现var els = $('.el');// 原生JavaScript实现var els = document.querySelectorAll('.el');// 简写var $ = function (el) {  return document.querySelectorAll(el);}var els = $('.el');

  创建元素

// jQuery 实现var newEl = $('
');// 原生JavaScript实现var newEl = document.createElement('div');

  事件、监听器操作

// jQuery 实现$('.el').on('event', function() {});// 原生JavaScript实现[].forEach.call(document.querySelectorAll('.el'), function (el) {  el.addEventListener('event', function() {  }, false);});

  设置、修改和获取属性值

// jQuery 实现$('.el').filter(':first').attr('key', 'value');$('.el').filter(':first').attr('key');// 原生JavaScript实现document.querySelector('.el').setAttribute('key', 'value');document.querySelector('.el').getAttribute('key');

  增加/修改/删除/反转 类操作

// jQuery 实现$('.el').addClass('class');$('.el').removeClass('class');$('.el').toggleClass('class');// 原生JavaScript实现document.querySelector('.el').classList.add('class');document.querySelector('.el').classList.remove('class');document.querySelector('.el').classList.toggle('class');

  追加元素 Append

// jQuery 实现$('.el').append($('
'));// 原生JavaScript实现document.querySelector('.el').appendChild(document.createElement('div'));

  复制、克隆元素

// jQuery 实现var clonedEl = $('.el').clone();// 原生JavaScript实现var clonedEl = document.querySelector('.el').cloneNode(true);

  删除元素

// jQuery 实现$('.el').remove();// 原生JavaScript实现remove('.el');function remove(el) {  var toRemove = document.querySelector(el);  toRemove.parentNode.removeChild(toRemove);}

  父元素操作

// jQuery 实现$('.el').parent();// 原生JavaScript实现document.querySelector('.el').parentNode;

  前一个/下一个/临近同辈元素

/ jQuery 实现$('.el').prev();$('.el').next();// 原生JavaScript实现document.querySelector('.el').previousElementSibling;document.querySelector('.el').nextElementSibling;

  

XHR aka AJAX

新版的JavaScript API里提供了一个全新的可以实现ajax的API——,这个api采用了全新的  架构,使用起来更方便,更灵活,详细用法请参考《》。

下面是传统的实现方式:

// jQuery 实现$.get('url', function (data) {});$.post('url', {data: data}, function (data) {});// 原生JavaScript实现// getvar xhr = new XMLHttpRequest();xhr.open('GET', url);xhr.onreadystatechange = function (data) {}xhr.send();// postvar xhr = new XMLHttpRequest()xhr.open('POST', url);xhr.onreadystatechange = function (data) {}xhr.send({data: data});

  不可否认,jQuery有时候是开发项目时必不可少的,但不同的项目,不同的场景,项目的技术架构,都需要做不同的考量,经过冷静的思考,我们就会发现,很多时候,我并不需要jQuery,使用原生JavaScript技术反而项目变得更精简、效率更高。

转载于:https://www.cnblogs.com/xupeiyu/p/5066480.html

你可能感兴趣的文章
iOS 一个比较完美的 Growing TextView
查看>>
dubbo+zookeeper+springmvc+mybatis分布式大型互联网企业架构
查看>>
关于 异步 的一些思考
查看>>
密码学基础(二)算法和密钥
查看>>
Android内存泄漏场景
查看>>
你觉得程序员最大的悲哀是什么?
查看>>
公众号是怎么赚钱的
查看>>
前端开发学习Day16
查看>>
云服务器都是有哪些特点? 云服务器有更高的性价比
查看>>
Effective Objective-C 2.0 第一章学习
查看>>
微服务分布式企业框架 Springmvc+mybatis+shiro+Dubbo+ZooKeeper+Redis+KafKa
查看>>
技术专栏丨从原理到应用,Elasticsearch详解(下)
查看>>
Python数据分析入门(三)
查看>>
JavaScript面向对象详解(原理)
查看>>
一个用Git交互可视化教学的项目
查看>>
LSM存储引擎基本原理
查看>>
webstrom编辑器scss环境以及ES6环境配置
查看>>
使用 Hbuild 快速构建生成现代化前端项目
查看>>
Windows虚拟环境在PyCharm中的使用
查看>>
CentOS安装JDK
查看>>