手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >Javascript学习笔记2 函数
Javascript学习笔记2 函数
摘要:就像我们可以写成这样的形式一样:复制代码代码如下:functionHello(){alert("Hello");}Hello();varHe...

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

复制代码 代码如下:

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引擎也就不会把他们放到一起了。

【Javascript学习笔记2 函数】相关文章:

Javascript 小技巧全集第1/4页

JavaScript中length属性的使用方法

Javascript实现的SHA-256加密算法完整实例

javascript带回调函数的异步脚本载入方法实例分析

Javascript 字符串模板的简单实现

javascript字符串与数组转换汇总

javascript实现获取服务器时间

JavaScript Date对象详解

javascript实现仿腾讯游戏选择

javaScript中with函数用法实例分析

精品推荐
分类导航