扫码关注官方订阅号
var sayYo = function () { alert("sayYo2!"); } console.log(sayYo);
此语句为什么可以打印出函数的代码?
光阴似箭催人老,日月如移越少年。
你不想他打印出函数代码,可以修改。 Function.prototype.toString = function(){ //你想打印的东西 } var sayYo = function () { alert("sayYo2!"); } console.log(sayYo);
因为它就是这样设计的。其自带魔法属性:查看对象内部结构。
http://stackoverflow.com/docu...
事实上,当你调用 console.log(func) 时,实际打印的是:func.toStirng(),toString 默认打印函数体,当然你可以覆盖这个函数:
console.log(func)
func.toStirng()
toString
func = function () {} func.toString = () => '看不到我' console.log(func) // ===> function 看不到我
你这个sayYo是个函数的引用啊,你要调函数得:
console.log(sayYo())
Javascript里面函数是可以像变量一样操作的
要理解这个,首先你要知道function也是一个对象。任何一个对象都有toString()方法(默认继承自Object,自己可以重写),此方法返回一个字符串。
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
因为它就是这样设计的。其自带魔法属性:查看对象内部结构。
http://stackoverflow.com/docu...
事实上,当你调用
console.log(func)时,实际打印的是:func.toStirng(),toString默认打印函数体,当然你可以覆盖这个函数:你这个sayYo是个函数的引用啊,你要调函数得:
Javascript里面函数是可以像变量一样操作的
要理解这个,首先你要知道function也是一个对象。
任何一个对象都有toString()方法(默认继承自Object,自己可以重写),此方法返回一个字符串。