简要咨询咨询QQ网站导航网站搜索手机站点联系我们设为首页加入收藏 

如何学好JavaScript(二)—— 函数

来源:易贤网   阅读:746 次  日期:2015-04-22 11:20:34

温馨提示:易贤网小编为您整理了“如何学好JavaScript(二)—— 函数”,方便广大网友查阅!

在Javascript中,function才是Javascript的第一型。当我们写下一段函数时,其实不过是建立了一个function类型的实体。

就像我们可以写成这样的形式一样:

function Hello() {

alert("Hello");

}

Hello();

var Hello = function () {

alert("Hello");

}

Hello();其实都是一样的。

但是当我们对其中的函数进行修改时,会发现很奇怪的问题。

<script type="text/javascript">

function Hello() {

alert("Hello");

}

Hello();

function Hello() {

alert("Hello World");

}

Hello();

script>

我们会看到这样的结果:连续输出了两次Hello World。而非我们想象中的Hello和Hello World。

这是因为Javascript并非完全的按顺序解释执行,而是在解释之前会对Javascript进行一次“预编译”,在预编译的过程中,会把定义式的函数优先执行,也会把所有var变量创建,默认值为undefined,以提高程序的执行效率。也就是说上面的一段代码其实被JS引擎预编译为这样的形式:

<script type="text/javascript">

var Hello = function() {

alert("Hello");

}

Hello = function() {

alert("Hello World");

}

Hello();

Hello();

script>

我们可以通过上面的代码很清晰地看到,其实函数也是数据,也是变量,我们也可以对“函数“进行赋值(重赋值)。当然,我们为了防止这样的情况,也可以这样:

<script type="text/javascript">

function Hello() {

alert("Hello");

}

Hello();

script>

<script type="text/javascript">

function Hello() {

alert("Hello World");

}

Hello();

script>

这样,程序被分成了两段,JS引擎也就不会把他们放到一起了。

更多信息请查看IT技术专栏

更多信息请查看脚本栏目
点此处就本文及相关问题在本站进行非正式的简要咨询(便捷快速)】     【点此处查询各地各类考试咨询QQ号码及交流群
上一篇:JavaScript禁止右键及粘贴复制
下一篇:用JS检查电话号码是否正确
易贤网手机网站地址:如何学好JavaScript(二)—— 函数
由于各方面情况的不断调整与变化,易贤网提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!