JavaScript学习笔记二——函数

系列文章导航:

JavaScript学习笔记一——数据类型

JavaScript学习笔记二——函数

JavaScript学习笔记三——作用域

JavaScript学习笔记四——Eval函数

JavaScript学习笔记五——类和对象

JavaScript学习笔记六:prototype的提出

Javascript学习笔记七——原型链的原理

Javascript学习笔记八——用JSON做原型

Javascript学习笔记九——prototype封装继承

Javascript学习笔记十——网页运行原理

Javascript学习笔记十一——包装DOM对象

Javascript学习笔记十三——关于响应事件

Javascript学习笔记十二——Ajax入门


  在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知识库JavaScript学习笔记二——函数,转载需保留来源!

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。