为什么放弃jQuery

本文探讨了为什么随着ECMAScript标准的更新,开发者开始放弃jQuery,转向原生JavaScript和现代API。文章提到,fetch API的出现使得ajax不再必要,而且原生JavaScript可以轻松实现jQuery的大部分功能。作者还提供了部分jQuery API的原生实现对比,并分享了一个简单的原生实现类jQuery库的示例。
摘要由CSDN通过智能技术生成

一. 前言

首先,直接操作dom的编程方式已经成为过去,数据驱动才是正途!
其次,不一定非要舍弃jQuery,只是可以,选择权在自己手上!
下面只是就事论事

二. 落幕

2018年7月 全球最大的同性交友社区(Github)被微软收购后的 52 天,改版并放弃了 jQuery 。这一举动让我等搬运工陷入了沉思。

三.Why?

随着ECMAScript标准的更新,原生js已经可代替jQuery,给我babel一个面子,不要再说兼容不支持的话!
下面举两个比较常用的方面来说明:

  • jQuery Api可以使用原生轻松实现
  • 使用 fetch 来代替 ajax;
    Fetch API 是基于 Promise 设计,更符合目前的异步解决方案。什么是目前的异步解决方案?翻看上一篇async & await

四.具体实现对比(部分)

1.选择器

    //jq
    $("#a .b");

    //Native
    document.querySelectorAll("#a .b");

2.插入

    //jq
    $(selector).append(html);
    //prepend
    //before
    //after

    //Native
    document.querySelectorAll(selector).insertAdjacentHTML("beforeend", html);
   //beforebegin 开始标签之前 before
   //afterbegin  开始标签之后 prepend
   //beforeend  结束标签之前 append
   //afterbegin  结束标签之后 after

3.类操作

    //jq
    $(selector).addClass(className);
    //hasClass
    //removeClass
    //toggleClass

    //Native
    document.querySelectorAll(selector).classList.add(className, className, className...);
   //contains(className) 检测是否存在
   //removeClass(className, className, className...) 删除
   //toggle(className, true|false) 切换

4.ajax

    //jq
    $.ajax({
   
        //.................
    });

    //Native
    (async () => {
   
     try{
   
        const res = await req(url, {
   headers: {
   Accept: "text/html"}});
        if(......){
   
           .......
        }
      } catch {
   
      
      }
    }());

    function req(url, data) {
       //自己封装,仅供参考
      let sendurl = url;
      
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值