首頁 >web前端 >js教程 >js類型判斷使用詳解

js類型判斷使用詳解

php中世界最好的语言
php中世界最好的语言原創
2018-05-28 13:50:261142瀏覽

這次帶給大家js類型判斷使用詳解,js類型判斷使用的注意事項有哪些,下面就是實戰案例,一起來看一下。

js型別轉換中typeof會將null也辨識為object, 而且回傳的型別比少,我們用Object.prototype.toString來實作

第一版

function isArray(value){
  return Object.prototype.toString.call(value) === "[object Array]";
}
function isFunction(value){
  return Object.prototype.toString.call(value) === "[object Function]";
}

但是這樣寫,一個個去判斷數組,函數,物件的話很麻煩,比較過程化

第二版

我們想要用type(obj)的方式回傳對應的型別字串,因為typeof是小寫,所以我們也回傳小寫的標準

function type(obj){
  // -1 代表截止到倒数一位
  return Object.prototype.toString.call(obj).slice(8,-1).toLowerCase()
}
type([]) // "array"

但是這樣每次都需要對判斷的類型進行slice和toLowerCase也是比較耗性能的, 而且判斷類型只有幾種,所以我們可以用物件提前將可能的結果快取起來

##第三版

//将types放外面 而不是放在type函数里面, 利用闭包,优化性能,不用每次判断都声明一次typess
var types = {
  '[object Function]': 'function',
  '[object Number]': 'number',
  ...
}
function type(obj) {
  var str = Object.prototype.toString.call(obj)
  return types[str]
}
當然上面的types我們還可以這樣優化

// 参考自jquery源码
var types = {}
当然也可以直接用数组存储
"Boolean Number String Function Array Date RegExp Object Error".split(" ").forEach(function(e,i){
  types [ "[object " + e + "]" ] = e.toLowerCase();
}) ;

判斷window物件

利用window物件的window屬性等於自身

function isWindow( obj ) {
  // obj !== undefined 是为了防止没传参数的时候后面报错
  // Uncaught TypeError: Cannot read property 'window' of undefined的错误
  
  return obj !== undefined && obj === obj.window;
}

判斷是不是dom元素

isElement = function(obj) {
  return !!(obj && obj.nodeType === 1);
}
我相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

怎麼使用vue.js中v-model指令實作資料雙向綁定

如何使用vue中swiper
#

以上是js類型判斷使用詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn