zoukankan      html  css  js  c++  java
  • jQuery? 回归JavaScript原生API

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

    原文首链:http://www.jeffjade.com/2015/11/25/2015-11-31-jQuery-vs-javaScript/

    在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实现相同操作的等价代码:

    选择元素

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

    创建元素

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

    添加/移除/切换类

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

    判断是否包含类

    // 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")){}
    

    添加事件监听器

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

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

    //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

    //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) {
    	BindEvent = function (dom, event, handle) {
          dom.attachEvent('on' + event, handle);
        }
      } else {
        BindEvent = function (dom, event, handle) {
          dom['on' + event] = handle;
        }
      }
      BindEvent(dom, event, handle, ex);
    };
    

    设置/获取属性

    // jQuery  
    $('.el').filter(':first').attr('key', 'value');  
    $('.el').filter(':first').attr('key');  
    
    //==========================================================// 
    // 原生方法  
    document.querySelector('.el').setAttribute('key', 'value');  
    document.querySelector('.el').getAttribute('key');  
    

    附加内容(Append)

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

    克隆元素

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

    移除元素

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

    获取父元素

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

    上一个/下一个元素

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

    修改CSS属性

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

     //----设置CSS属性----
    
    /* jQuery */
      $(el).css({
        background: "#FF0000",
    "box-shadow": "1px 1px 5px 5px red",
         "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

    // 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

  • 相关阅读:
    在小程序开发的新风口 看华为云如何助立创科技抢占市场红利
    华为云软件开发云助力集时通软件敏捷开发
    一站式云端安卓软件开发工具的体验之路!
    一名优秀的全栈工程师必需的开发工具
    学哪种编程语言更有“钱”赚?
    深度剖析:最新云端开发工具如何实现敏捷+DevOps开发落地
    软件开发未来发展五大趋势,从业者们注意了!
    十个最有“钱景”的IT技能, 你掌握了哪个?
    “敏捷开发”之白话篇
    解决软件开发中的多个痛点——华为软件开发云
  • 原文地址:https://www.cnblogs.com/jadeboy/p/5043401.html
Copyright © 2011-2022 走看看