严格模式及高阶函数

严格模式的定义

  • JavaScript 除了提供正常模式外,还提供了严格模式( strictmode )。ES5 的严格模式是采用具有限制性
  • JavaScript 变体的一种方式,即在严格的条件下运行JS代码。
  • 严格模式在IE10以上版本的浏览器中才会被支持,旧版本浏览器中会被忽略。
  • 严格模式对正常的JavaScript语义做了一一些更改 :
    1.消除了Javascript语法的一些不合理、不严谨之处,减少了-些怪异行为
    2.消除代码运行的一些不安全之处 ,保证代码运行的安全。
    3.提高编译器效率,增加运行速度。
    4.禁用了在ECMAScript的未来版本中可能会定义的一些语法,为未来新版本的Javascript做好铺垫。比如一-些保留字如: class, enum, export, extends, import, super不能做变量名

开启严格模式

<!-- 为整个脚本(script标签)开启严格模式 -->
    <script>
        'use strict';
        //   下面的js 代码就会按照严格模式执行代码
    </script>
    <script>
        (function() {
            'use strict';
        })();
    </script>
    <!-- 为某个函数开启严格模式 -->
    <script>
        // 此时只是给fn函数开启严格模式
        function fn() {
            'use strict';
            // 下面的代码按照严格模式执行
        }

        function fun() {
            // 里面的还是按照普通模式执行
        }
    </script>

严格模式的变化

1.变量规定
①在正常模式中,如果一个变量没有声明就赋值,默认是全局变量。严格模式禁止这种用法,变量都必须先用var命令声明,然后再使用。
num = 10;
// console.log(num);
var num = 10;
console.log(num);
②严禁删除已经声明变量。例如, delete x;语法是错误的。delete num;

2.严格模式下this的指向问题
在这里插入图片描述

function fn() {
            console.log(this); // undefined。
        }
        fn();
function Star() {
            this.sex = '男';
        }
        // Star(); 会报错
        var ldh = new Star();
        console.log(ldh.sex);

3.函数变化
①函数不能有重名的参数。
②函数必须声明在顶层新版本的JavaScript会引入"块级作用域” ( ES6中已引入)。为了与新版本接轨,不允许在非函数的代码块内声明函数。
更多严格模式要求参考: https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Strict mode

 function fn(a, a) {
            console.log(a + a);

        };
        fn(1, 2);

高阶函数
定义:函数可以作为参数传递

 function fn(a, b, callback) {
            console.log(a + b);
            callback && callback();
        }
        fn(1, 2, function() {
            console.log('我是最后调用的');

        });
        $("div").animate({
            left: 500
        }, function() {
            $("div").css("backgroundColor", "purple");
        })
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值