1、安全的类型检测

  Object.prototype.toString.call(obj) => "[object NativeConstructorName]"

 /**
* 判断变量的类型
* @param {*} obj 需要判断的变量
* @return string "boolean/number/string/function/array/date/regExp/undefined/null/object"
*/
function getType (obj) {
const class2Type = {
'[object Boolean]': 'boolean',
'[object Number]': 'number',
'[object String]': 'string',
'[object Function]': 'function',
'[object Array]': 'array',
'[object Date]': 'date',
'[object RegExp]': 'regExp',
'[object Undefined]': 'undefined',
'[object Null]': 'null',
'[object Object]': 'object'
}
return class2Type[Object.prototype.toString.call(obj)] || 'object'
}

2、判断一个对象是否是window对象

 // 判断obj是否是window对象
function isWindow (obj) {
return obj !== null && obj === obj.window
}

3、判断一个对象是否是数组

 // 判断一个对象是否是数组
function isArray (obj) {
return Array.isArray ? Array.isArray(obj) : getType(obj) === 'array'
}

4、判断一个对象自身属性中是否具有指定的属性,非继承的属性

  Object.prototype.hasOwnProperty.call('propsName')

 o = new Object();
o.prop = 'exists';
o.hasOwnProperty('prop'); // 返回 true
o.hasOwnProperty('toString'); // 返回 false
o.hasOwnProperty('hasOwnProperty'); // 返回 false
 // 判断一个对象是否是纯粹的对象(通过 "{}" 或者 "new Object" 创建的)
function isPlainObject (obj) {
// Object的hasOwnProperty()方法返回一个布尔值,判断对象是否包含特定的自身(非继承)属性,true表示是自身的属性
const hasOwn = Object.prototype.hasOwnProperty // 不拷贝非对象、DOM对象、window对象
if (!obj || getType(obj) !== 'object' || obj.nodeType || isWindow(obj)) {
return false
}
try {
// Not own constructor property must be Object
if (obj.constructor &&
!hasOwn.call(obj, 'constructor') &&
!hasOwn.call(obj.constructor.prototype, 'isPrototypeOf')) {
return false
}
} catch (e) {
// IE8,9 Will throw exceptions on certain host objects #9897
return false
} // Own properties are enumerated firstly, so to speed up,
// if last one is own, then all properties are own.
var key
for (key in obj) {} return key === undefined || hasOwn.call(obj, key)
}

5、深浅拷贝

 // 用JQ中的extend的方法来进行对象的深浅拷贝
export function merge () {
let options
let name
let src
let copy
let copyIsArray
let clone
let target = arguments[0] || {} // 获取第一个参数的值
let i = 1
let length = arguments.length // 获取传入参数的个数
let deep = false // 深浅拷贝标识,true表示深拷贝,false表示前拷贝 // 判断第一个参数是否是boolean值,如果是,那么应该从第3个参数开始进行深拷贝,否则进行浅拷贝
// merge(deep,target,source1,source2...)
if (typeof target === 'boolean') {
deep = target
i = 2
target = arguments[1] || {} // 获取目标源
} // 对目标源target进行判断
if (typeof target !== 'object' && getType(target) !== 'function') {
target = {}
} // 如果只传入两个参数,没有源数据
// merge(true,{})
if ( length === i ) {
--i;
} for (; i < length; i++) {
// 处理非空的源参数
if ((options = arguments[i]) !== null) {
// 获取源参数中的key值
for (name in options) {
// 通过key值获取目标源和源中的值
src = target[name]
copy = options[name] // 避免死循环
if (target === copy) {
continue
}
// 深拷贝,只拷贝纯粹的obj或者数组
if (deep && copy && (isPlainObject(copy) || (copyIsArray = isArray(copy)))) {
// 拷贝的是数组
if (copyIsArray) {
copyIsArray = false
clone = src && isArray(src) ? src : []
} else {
clone = src && isPlainObject(src) ? src : {}
}
target[ name ] = merge(deep, clone, copy)
} else if (copy !== undefined) {
target[ name ] = copy
}
}
}
}
return target
}

PS:使用JSON.stringify()和JSON.parse()也可以实现深拷贝,也可以使用JSON.stringify来判断两个对象是否相等。

最新文章

  1. WooCommerce插件设置教程之设置主页
  2. java序列化
  3. github创建文件夹
  4. Hibernate实体关系映射(OneToMany、ManyToOne双边)——完整实例
  5. Hadoop学习(2)-- HDFS
  6. Mark Russinovich 的博客:Windows Azure 主机更新:原因、时间和方式
  7. Mysql 免安装版 root@localhost第一次密码设置
  8. gradle2.0笔记——让项目升级到gradle2.0
  9. height:auto 火狐没边框
  10. jmeter笔记(8)--关联
  11. django - 总结 - 中间件
  12. (三)Javascript面向对象编程:非构造函数的继承
  13. NOIP2016解题报告
  14. 仿迅雷播放器教程 -- 提取exe资源(12)
  15. c# 进阶之 WebAPI
  16. 雷林鹏分享:jQuery EasyUI 树形菜单 - 使用标记创建树形菜单
  17. hdu1166 敌兵布阵【线段树】
  18. redis安装 phpredis Jedis 扩展的实现及注意事项,php,java,python相关插件安装实例代码和文档推荐
  19. Go Web 使用工具
  20. Codeforces Round #299 (Div. 2)A B C 水 dfs 二分

热门文章

  1. windows下C语言头文件的运用
  2. IO流大文件拷贝
  3. 【细谈Java并发】谈谈LinkedBlockingQueue(转)
  4. SQL SERVER 表添加新字段
  5. Codevs 3012 线段覆盖 4
  6. python 绘制sinx
  7. 巨丑vue
  8. easyExcel简介#
  9. Oracle数据库本地和远程导入、导出
  10. JWT加密解密