JavaScript学习笔记二——函数

本文深入探讨了JavaScript中函数的本质及特殊行为,特别是函数作为第一等公民的特点,以及函数重定义时由于JavaScript引擎预编译机制导致的现象。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值