爱易网
IT新闻
IT新闻
爱易资讯
网站搭建
云虚拟主机教程
云服务器教程
Apache教程
IIS教程
Nginx教程
网站策划
站长文章
推广教程
淘宝客教程
网页设计
HTML教程
XHTML教程
CSS教程
HTML5教程
CSS3教程
JavaSript基础
JQuery教程
Node.js教程
前端技术
Ajax教程
Js特效
Xml教程
平面设计
页面UI设计
photoshop教程
程序开发
AI人工智能
Asp教程
Php教程
Asp.Net教程
Net Core教程
C#教程
Java教程
Jsp教程
开发技术
微信小程序教程
Uniapp开发教程
微信公众号开发
Andriod教程
IOS教程
DOS教程
Python教程
Docker教程
Windows Container教程
数据库
MSSQL教程
MySQL教程
Redis教程
Access教程
Oracle教程
数据库教程
操作系统
Linux教程
Windows教程
MAC教程
Cisco教程
交换机教程
防火墙教程
搜索
爱易网页
JavaSript
{{JS}}function话语
{{JS}}function话语
日期:2014-05-16 浏览次数:20327 次
{{JS}}function语句
请问以下语句输出结果是:
alert(f(4));
var f = 0;
function f(x) {
return x + 1;
}
alert(f);
答案是:
// 5
// 0
这里需要解释下原因——出现这种结果的原因是由于函数定义和变量定义发生在不同的时刻.
在JS中函数定义发生在解析时,而不是在运行时.
当JS解析程序遇到一个函数定义时它就会解析并存储(而无需执行)构成函数主体的语句,然后定义一个和该函数同名的属性(如果函数定义嵌套在其它函数中,那么就会在调用对象中定义这个属性,否则在全局对象中定义这个属性)以保存它.
如上说法,你就能明白为什么JS中强调函数定义不能出现在if/while或其它语句中,如下
if(a === 1) {
function get(param) {
return param + 1;
}
} else {
function get(param) {
return param + 2;
}
}
由于函数定义发生在解析时,故get函数始终为第二个.
上一篇: ssh如何知道删除实体成不成功
下一篇: {{JS}}相仿数组的对象
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
div跟onmouseout的有关问题
能否在某个网页元素后面增加东西?解决办法
jstat施用浅谈
json中关于处置数据的方法 json-lib
JS实现相仿excel的表格数据输入,并自动计算的页面
做了一个简易的焦点图!求批.该怎么解决
请教obj.add 的有关问题
【帮忙通译一下下面的JS】给分哦
<a href="javascript:void(零)"></a>
推荐阅读
更多>
代码中的问号是什么意思呀,该怎么处理
json 简略介绍
JS绑定事件的函数步骤—addEventListener()和attachData()
怎么获取标签元素里的文本内容字符数
json跟bean转换
javascript几种操作报表方法的性能对比
js 文字下上滚动效果
Json跟实体对象的转换
ExtJS 停 Ext.Direct 加载和提交排错小结
iframe WINDOW.PARENT 的兼容有关问题
JS简略日期比较
刷新页面清空表单的有关问题
ExtJS API或官方例子不能显示有关问题
怎么用 js 让 <tr> 不可用?
JS操作js高级技艺(小结)
参数传递有关问题
JavaScript连接ACCESS数据库的有关问题
学习JS的步骤
js日期有关问题
关于chrome和firefox浏览器获取iframe中的对象有关问题