在JavaScript的世界里,嵌套对象属性的访问总是让人头疼不已,尤其是当属性路径复杂多变时。今天,我要为大家揭秘一款神奇的武器——手写的get函数,它将轻松解决你的嵌套对象属性访问难题!
首先,让我们来认识一下这款神奇的get函数。它接收三个参数:一个对象obj
,一个路径字符串path
,以及一个可选的默认值defaultValue
。通过这个函数,你可以安全地访问嵌套对象的属性,而不用担心遇到null
或undefined
的情况。
function get(obj, path, defaultValue) {
const pathArray = Array.isArray(path) ? path : path.split(/.|$$/).filter(p => p !== '');
let current = obj;
for (const key of pathArray) {
if (current === null || current === undefined) {
return defaultValue;
}
current = current[key];
}
return current === undefined ? defaultValue : current;
}
这个函数的强大之处在于它的路径处理能力。如果path
是一个数组,那么它会直接使用;如果path
是一个字符串,那么它会按照.
、[
或]
进行分割,并过滤掉空字符串。例如,对于字符串'a[0].b'
,它会转换为数组['a', '0', 'b']
。
接下来,我们来看看这个函数的逐层访问能力。它会遍历路径数组,依次访问对象的属性。如果在中间遇到null
或undefined
,那么它会立即返回默认值。
最后,让我们来看看这个函数的返回值处理能力。如果最终值为undefined
,那么它会返回默认值;否则,它会返回实际值。
为了让大家更直观地了解这个函数的使用方法,我给大家准备了一些示例用法:
const obj = {
a: {
b: [ { c: 3 } ]
}
};
console.log(get(obj, 'a.b.0.c')); // 3
console.log(get(obj, ['a', 'b', '0', 'c'])); // 3
console.log(get(obj, 'a.x', 'default')); // 'default'
console.log(get(null, 'a.b')); // undefined
当然,这个函数也有一些需要注意的地方。首先,如果属性名含有.
或[]
,那么你需要使用数组形式的路径(如['a.b', 'c']
)。其次,如果你需要支持更复杂的路径(如带引号的字符串),那么你可能需要扩展路径解析逻辑。
总之,手写的get函数是一款强大而实用的工具,它可以帮助你轻松解决嵌套对象属性访问的难题。现在,你是否已经迫不及待想要尝试一下了呢?
声明:
1、本博客不从事任何主机及服务器租赁业务,不参与任何交易,也绝非中介。博客内容仅记录博主个人感兴趣的服务器测评结果及一些服务器相关的优惠活动,信息均摘自网络或来自服务商主动提供;所以对本博客提及的内容不作直接、间接、法定、约定的保证,博客内容也不具备任何参考价值及引导作用,访问者需自行甄别。
2、访问本博客请务必遵守有关互联网的相关法律、规定与规则;不能利用本博客所提及的内容从事任何违法、违规操作;否则造成的一切后果由访问者自行承担。
3、未成年人及不能独立承担法律责任的个人及群体请勿访问本博客。
4、一旦您访问本博客,即表示您已经知晓并接受了以上声明通告。
本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。
Copyright 2005-2024 yuanmayuan.com 【源码园】 版权所有 备案信息
声明: 本站非腾讯QQ官方网站 所有软件和文章来自互联网 如有异议 请与本站联系 本站为非赢利性网站 不接受任何赞助和广告