不要過分依賴JQuery(三)

在這裏先拜個年,祝你們新年快樂,闔家幸福,步步高昇!node

迴歸正題,在不要過分依賴JQuery(一)不要過分依賴JQuery(二)兩篇文章中已經列舉了大量的使用原生JavaScript替代JQuery的例子,在本文中將繼續列舉!數組

一、表單dom

獲取焦點函數

$('#test').focus();  
$('#test').focus(function(){});

var t = document.getElementById('test');
function addEvent(dom, type, handle, capture) {       
  if(dom.addEventListener) {       
    dom.addEventListener(type, handle, capture);        
  } else if(dom.attachEvent) {       
    dom.attachEvent("on" + type, handle);       
  } 
}; 
function focus(elem, fn) {
  if(fn && typeof fn === 'function') {
    addEvent(elem, 'focus', fn);
  } else {
    elem.focus();
  }
}

focus(t, function(){});

失去焦點oop

$('#test').blur();
$('#test').blur(function(){});
   
function blur(elem, fn) {    
  if(fn && typeof fn === 'function') {    
    addEvent(elem, 'blur', fn);    
  } else {    
    elem.blur();    
  }   
}    

blur(t, function(){});

實時監控this

$('#test').on('input propertychange', fn);

function inputChange(dom, fn, capture) {   
  capture = capture || false;   
  addEvent(dom, 'input', fn, capture);
  addEvent(dom, 'propertychange', fn, capture);   
}

inputChange(t, function(){});

二、判斷類型prototype

判斷類型code

$.type(obj);

Object.prototype.toString.call(obj).replace(/^\[object (.+)\]$/, '$1').toLowerCase();

判斷是否爲一個函數對象

$.isFunction(fn)

function isFunction(fn){
  return typeof fn === 'function';
}

判斷是否爲數字ip

$.isNumeric(num);

function isNumber(num) {
  var type = typeof num;
  return ( type === 'number' || type === 'string') && 
      !isNaN( num - parseFloat( num ) );
}

判斷是否爲數組

$.isArray(obj);

function isArray(obj) {
  if( Array.isArray ) {
    return Array.isArray(obj);
  } else {
    return Object.prototype.toString.call(obj) === '[object Array]';
  }
}

三、時間

獲取當前時間

$.now()

new Date().getTime();

/* 更簡單 */
+new Date();

四、改變上下文(this)

$.proxy(fn, context);

fn.bind(context);

五、空函數

建立一個空函數

var fn = $.noop();

var fn = function() {}

六、數組

合併數組

$.merge(arr1, arr2)

function (arr1, arr2) {
  return arr1.concat(arr2);
}

類數組對象轉換成數組

var divs = document.querySelectorAll('div');

var arr = $.makeArray(divs);

var arr = Array.prototype.slice.call(divs);

// ES6 
var arr = Array.from(divs)

七、Iframe

獲取iframe的document

$('#iframe').contents();

var iframe = document.getElementById('iframe');
iframe.contentDocument;

八、元素包含關係

檢查一個DOM元素是另外一個DOM元素的後代

$.contains(parent, child);

function contains(root, el) { 
  /* Chrome / Firefox */  
  if (root.compareDocumentPosition) {  
    return root === el || !!(root.compareDocumentPosition(el) & 16);  
  } 
  /* IE */
  if (root.contains && el.nodeType === 1){   
    return root.contains(el) && root !== el;   
  }   
  while ((el = el.parentNode)) {  
    if (el === root) { return true; }  
    return false;   
  }
}

九、scroll

設置/獲取window滾動位置

/*獲取*/
$(window).scrollTop();

(document.documentElement && document.documentElement.scrollTop) || document.body.scrollTop

/*設置*/
$(window).scrollTop(10);

(document.documentElement && document.documentElement.scrollTop = 10) || document.body.scrollTop = 10;

設置某個元素滾動位置

$('#test').scrollTop(10);

var t = document.getElementById('test');

t.scrollTop = 10;

注意:別加單位!

十、節點

獲取元素的最近的祖先定位(position非static)元素

$('#test').offsetParent();

var t = document.getElementById('test');
t.offsetParent;

到這裏,《不要過分依賴JQuery》系列就告一段落了!

原文連接:不要過分依賴JQuery(三)

若有錯誤或建議,歡迎在下方評論區留言!

相關文章
相關標籤/搜索