Jquery的深浅拷贝涉及到的知识点
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来判断两个对象是否相等。
Jquery的深浅拷贝涉及到的知识点的更多相关文章
- python中set(集合),深浅拷贝以及一些补充知识点
1.set集合 特点:无序,不重复,元素必须可哈希(不可变) 作用:去重复 本身是可变的数据类型.有增删改查操作.{集合的增删改查操作应用较少,这里不做详细介绍了(这里的增有一个方法update注意这 ...
- 深浅拷贝, for循环小知识点 str操作 list的删除问题,类型转换
深浅拷⻉ : lst1 = ["⾦⽑狮王", "紫衫⻰王", "⽩眉鹰王", "⻘翼蝠王"] lst2 = lst1 ...
- 深浅拷贝,原生和JQuery方法实现
7-17: 1:e.target.parentNode.remove();成功,查询一下JS原生的remove方法 2:复习JS DOM的原生操作方法,比如innerHTML(),insertBefo ...
- 知识点补充 set 深浅拷贝
一 对前面知识点的补充 1.str中的join()方法是将列表转换成字符串 lst = ["韩雪","赵丽颖","黄渤","李连杰 ...
- python学习打卡 day07 set集合,深浅拷贝以及部分知识点补充
本节的主要内容: 基础数据类型补充 set集合 深浅拷贝 主要内容: 一.基础数据类型补充 字符串: li = ["李嘉诚", "麻花藤", "⻩海峰 ...
- jQuery开发插件的两个方法 js 深浅拷贝
1.jQuery.extend(object);为扩展jQuery类本身.为类添加新的方法.由全局函数来调用, 主要是用来拓展个全局函数 2.jQuery.fn.extend(object);为jQu ...
- Python-Day3知识点——深浅拷贝、函数基本定义、内置函数
一.深浅拷贝 import copy #浅拷贝 n1={'k1':'wu','k2':123,'k3':['carl',852]} n2=n1 n3=copy.copy(n1) print(id(n1 ...
- set集合,深浅拷贝以及部分知识点补充
目录: 1.基础数据类型补充 2.set集合 3.深浅拷贝 一,基础数据类型补充 字符串的基本操作 li = ["李李嘉诚", "麻花藤", "⻩黄海 ...
- python day- 7 进本数据类型的先关知识点 set集合 深浅拷贝
一.基本数据类型相关知识 1.str. join()函数 关于字符串 a = "我爱北京" b = a.join("真的") 将&q ...
随机推荐
- 外观模式(Facade)---结构型模式
1 基础知识 定义:提供了一个统一的接口(外观类),用来访问子系统中的一群接口.特征:定义了一个高层接口让子系统更容易使用,减少了外部与子系统内多个模块的耦合. 本质:封装交互,简化调用. 优点:简化 ...
- HDU 5852 Intersection is not allowed! ( 2016多校9、不相交路径的方案、LGV定理、行列式计算 )
题目链接 题意 : 给定方格中第一行的各个起点.再给定最后一行与起点相对应的终点.问你从这些起点出发到各自的终点.不相交的路径有多少条.移动方向只能向下或向右 分析 : 首先对于多起点和多终点的不相交 ...
- 前端vue的get和post请求
vue的get和post需要两个文件vue.js和vue-resource.js 以下是实现的代码,可以参考一下,需要注意的接口的请求需要考虑跨域的问题,其次就是访问页面需要在tomcat下访问,否则 ...
- Android项目实战登录&注册
由于项目中大部分界面都有一个后退键和一个标题栏,为避免代码冗杂以及便于利用,我们可以将后推荐和标题栏单独抽取出来定义一个标题栏布局,在 res/layout 目录下新建一个 Layout resour ...
- python 处理 json 四个函数dumps、loads、dump、load的区别
1 .json.dumps() 函数是将一个 Python 数据类型列表(可以理解为字典)进行json格式的编码(转换成字符串,用于传播)eg, dict = {"age": &q ...
- Django基础之命名URL和URL反向解析
在使用Django项目时,一个常见的需求是获得URL的最终形式,以用于嵌入到生成的内容中(视图中和显示给用户的URL等)或者用于处理服务器端的导航(重定向等). 人们强烈希望不要硬编码这些URL(费力 ...
- 【maven】【spring boot】【单元测试】 使用controller 执行单元测试类
存在这样一个场景: 当项目启动时间过长,又没办法缩短的时候,写单元测试就是一个十分耗时的工作, 这工作不在于使用编写代码,而在于每次run junit test 都需要完整启动一次项目,白白浪费宝贵的 ...
- 安装mongodb-window10版
第一.下载mongodb 官方地址:https://www.mongodb.com/ 第二步mongodb安装 运行mongodb-win32-x86_64-2008plus-ssl-v3.4-lat ...
- HTTP缓存机制和原理
前言 Http 缓存机制作为 web 性能优化的重要手段,对于从事 Web 开发的同学们来说,应该是知识体系库中的一个基础环节,同时对于有志成为前端架构师的同学来说是必备的知识技能.但是对于很多前端同 ...
- Linux-ubuntu英文版输入法不能切换中文输入法问题解决办法
1:System Settings中点击Language Support 2. 3. 4. 5. 6. 7.注意不要勾选Only Show Current Language