【JavaScript】15_debug,立即执行函数 与 严格模式

14、debug

        <script>

            //debugger // 在代码中打了一个断点

            console.log(a) // 2

            var a = 1

            console.log(a) // 1

            function a() {
                alert(2)
            }

            console.log(a) // 1

            var a = 3

            console.log(a) // 3

            var a = function () {
                alert(4)
            }

            console.log(a) // 4

            var a

            console.log(a) // 4
        </script>

15、立即执行函数

​ 立即执行函数(IIFE)

  • 立即是一个匿名的函数,并它只会调用一次
  • ​可以利用IIFE来创建一个一次性的函数作用域,避免变量冲突的问题
    <script>
        /* 
            在开发中应该尽量减少直接在全局作用域中编写代码!
            所以我们的代码要尽量编写的局部作用域
            如果使用let声明的变量,可以使用{}来创建块作用域
        */
        {
            let a = 10
        }

        {
            let a = 20
        }

        // function fn(){
        //     var a = 10
        // }

        // fn()

        // function fn2(){
        //     var a = 20
        // }

        // fn2()

        //希望可以创建一个只执行一次的匿名函数

        /* 
            立即执行函数(IIFE)
                - 立即是一个匿名的函数,并它只会调用一次
                - 可以利用IIFE来创建一个一次性的函数作用域,避免变量冲突的问题
        */
        (function(){
            let a = 10
            console.log(111)
        }());


        (function(){
            let a = 20
            console.log(222)
        }())
    </script>

18、严格模式

JS运行代码的模式有两种:

正常模式

  • 默认情况下代码都运行在正常模式中,
    在正常模式,语法检查并不严格
    它的原则是:能不报错的地方尽量不报错
  • 这种处理方式导致代码的运行性能较差

严格模式

  • 在严格模式下,语法检查变得严格 --------> “use strict”
    1.禁止一些语法
    2.更容易报错
    3.提升了性能

  • 在开发中,应该尽量使用严格模式,
    这样可以将一些隐藏的问题消灭在萌芽阶段,
    同时也能提升代码的运行性能

    <script>
        "use strict" // 全局的严格模式
        let a = 10
        // console.log(a)

        function fn(){
            "use strict" // 函数的严格的模式
        }
    </script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

名之以父

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值