We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
本文为读 lodash 源码的第二百三十篇,后续文章会更新到这个仓库中,欢迎 star:pocket-lodash
gitbook也会同步仓库的更新,gitbook地址:pocket-lodash
import isObject from './isObject.js'
《lodash源码分析之isObject》
isNatve 用来检测 value 是否为原生内置函数。
isNatve
value
源码如下:
const reRegExpChar = /[\\^$.*+?()[\]{}|]/g const reIsNative = RegExp(`^${ Function.prototype.toString.call(Object.prototype.hasOwnProperty) .replace(reRegExpChar, '\\$&') .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') }$`) function isNative(value) { return isObject(value) && reIsNative.test(value) }
首先判断 value 是否为对象,再使用 reIsNative 来检测是否为原生内置的函数。
reIsNative
这里有几个点很有意思,首先使用 reIsNative 时,会隐式将 value 转换成 string ,如果 value 是函数的话,相当于调用了 toString 方法。
string
toString
然后,reIsNative 是根据所处的执行环境,动态生成的正则表达式。
Function.prototype.toString.call(Object.prototype.hasOwnProperty)
Object.prototype.hasOwnProperty 只要不做原型链方法的修改,就是一个原生函数,通过这样可以获得原生函数转换成字符串后的模板,然后根据这个模板生成正则。
Object.prototype.hasOwnProperty
为什么要通过模板来生成正则,而不是直接写出一个正则表达式呢?
这里因为,在不同的环境下,原生函数 toString 后的表现是不一样的。
如在某些浏览器中,toString 后是这样的:
"function hasOwnProperty() { [native code] }"
只有一行。
在某些浏览器中,toString 后是这样的:
`function hasOwnProperty() { [native code] }`
会有缩进和换行。
因此 lodash 一开始就通过一个原生函数来获取模板,然后将 name 部分替换。
lodash
name
reRegExpChar 会将 (){}[] 等特殊字符转义。
reRegExpChar
(){}[]
而 /hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g 这个正则,在正常情况下,只需要 /hasOwnProperty|(function).*?(?=\\\()/g 这样即可,用来匹配函数名。但是某些平台如 Rhino 会使用 for... 添加额外的信息。
/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g
/hasOwnProperty|(function).*?(?=\\\()/g
Rhino
for...
检测一个函数是否是JavaScript原生函数的小技巧
署名-非商业性使用-禁止演绎 4.0 国际 (CC BY-NC-ND 4.0)
最后,所有文章都会同步发送到微信公众号上,欢迎关注,欢迎提意见:
作者:对角另一面
The text was updated successfully, but these errors were encountered:
No branches or pull requests
本文为读 lodash 源码的第二百三十篇,后续文章会更新到这个仓库中,欢迎 star:pocket-lodash
gitbook也会同步仓库的更新,gitbook地址:pocket-lodash
依赖
《lodash源码分析之isObject》
源码分析
isNatve
用来检测value
是否为原生内置函数。源码如下:
首先判断
value
是否为对象,再使用reIsNative
来检测是否为原生内置的函数。这里有几个点很有意思,首先使用
reIsNative
时,会隐式将value
转换成string
,如果value
是函数的话,相当于调用了toString
方法。然后,
reIsNative
是根据所处的执行环境,动态生成的正则表达式。Object.prototype.hasOwnProperty
只要不做原型链方法的修改,就是一个原生函数,通过这样可以获得原生函数转换成字符串后的模板,然后根据这个模板生成正则。为什么要通过模板来生成正则,而不是直接写出一个正则表达式呢?
这里因为,在不同的环境下,原生函数
toString
后的表现是不一样的。如在某些浏览器中,
toString
后是这样的:"function hasOwnProperty() { [native code] }"
只有一行。
在某些浏览器中,
toString
后是这样的:会有缩进和换行。
因此
lodash
一开始就通过一个原生函数来获取模板,然后将name
部分替换。reRegExpChar
会将(){}[]
等特殊字符转义。而
/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g
这个正则,在正常情况下,只需要/hasOwnProperty|(function).*?(?=\\\()/g
这样即可,用来匹配函数名。但是某些平台如Rhino
会使用for...
添加额外的信息。参考
检测一个函数是否是JavaScript原生函数的小技巧
License
署名-非商业性使用-禁止演绎 4.0 国际 (CC BY-NC-ND 4.0)
最后,所有文章都会同步发送到微信公众号上,欢迎关注,欢迎提意见:
作者:对角另一面
The text was updated successfully, but these errors were encountered: