【JavaScript】ES6新特性(2)

news2025/1/16 18:01:09

5. 字符串扩展

5.1 includes函数

判断字符串中是否存在指定字符

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>字符串扩展的includes函数</title>
</head>

<body>
    <script>
        let myname = "ichdu";

        // includes 判断字符串中是否存在指定字符
        console.log(myname.includes("i")); // true
        console.log(myname.includes("d")); // true
        console.log(myname.includes("ich")); // true
        console.log(myname.includes("iu")); // false

        // startsWith 判断字符串是否开头字符串
        console.log(myname.startsWith('i')); // true
        console.log(myname.startsWith('ich')); // true

        // endsWith 判断字符串是否结尾字符串
        console.log(myname.endsWith('u')); // true
        console.log(myname.endsWith('du')); // true

        // 加入第二个位置参数
        // includes
        console.log(myname.includes("i")); // true
        // 以字符串索引值为 1 开始判断
        console.log(myname.includes("i", 1)); // false

        // startsWith
        console.log(myname.startsWith('i')); // true
        // 以字符串索引值为 1 开始判断
        console.log(myname.startsWith('i', 1)); // false

        // endsWith
        console.log(myname.endsWith('u')); // true
        // 以字符串倒数第三个开始判断
        console.log(myname.endsWith('u',3)); // false
        console.log(myname.endsWith('h',3)); // true
    </script>
</body>

</html>

5.2 repeat 函数

repeat()方法返回一个新字符串,表示将原字符串重复n次

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>字符串扩展的repeat函数</title>
</head>
<body>
    <script>
        let myname = "ichdu";

        console.log(myname.repeat(2)); // ichduichdu
        console.log(myname.repeat(2.8)); // ichduichdu,重复两次,把 0.8 切掉
        console.log(myname.repeat("aaa")); // 检测不出多少次,打印为空
        console.log(myname.repeat("4")); // 将字符串 “4” 转为数值 4 ,重复打印 4 次
    </script>
</body>
</html>

在这里插入图片描述

6. 数值扩展

6.1 二进制和八进制表示法

二进制表示法新写法: 前缀 0b 或 0B
八进制表示法新写法: 前缀 0o 或 0O

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>二进制和八进制表示法</title>
</head>

<body>
    <script>
        // 支持 二进制、八进制
        let num1 = 100;
        let num2 = 0x100; // 十六进制
        let num3 = 0b100; // 二进制
        let num4 = 0o100; // 八进制

        console.log(num1);
        console.log(num2);
        console.log(num3);
        console.log(num4);
    </script>
</body>

</html>

6.2 isFinite 与 isNaN方法

isFinite 方法

Number.isFinate 没有隐式的 Number() 类型转换,所有非数值都返回 false

传统新特性
isFinite()Number.isFinite()
检测一个值是否为有限值,如果是返回true,否则就是Infinity,返回false对于非数值一律返回false
当0做除数时,是一个无穷大的数,所以返回falseNumber.isFinite() 用来检查一个数值是否为有限的
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>isFinite 与 isNaN方法</title>
</head>

<body>
    <script>
        // Number.isFinite Number.isNaN

        // window 自带的 isFinite 方法,传统的全局方法isFinite()
        let num1 = isFinite(100);
        let num2 = isFinite(100 / 0);
        let num3 = isFinite(Infinity);
        let num4 = isFinite("100"); 

        console.log(num1); // true
        console.log(num2); // false
        console.log(num3); // false

        // 因为会先尝试转换成数值,再进行判断,所以为 true
        console.log(num4); // true

        // 新特性的全局方法isFinite()
        let num5 = Number.isFinite(100);
        let num6 = Number.isFinite(100 / 0);
        let num7 = Number.isFinite(Infinity);
        let num8 = Number.isFinite("100");

        console.log(num5); // true
        console.log(num6); // false
        console.log(num7); // false

        // Number.isFinite()对于非数值一律返回false
        console.log(num8); // false
    </script>
</body>

</html>

isNaN方法

传统新特性
isNaN()Number.isNaN()
检测一个值是否为NaN,隐式转为数字型,是NaN返回true,不是返回falseNumber.isNaN()只有对于NaN才返回true,非NaN一律返回false
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>isFinite 与 isNaN方法</title>
</head>

<body>
    <script>
        // Number.isFinite Number.isNaN
        // 传统的 isNaN() —— 检测一个值是否为NaN,隐式转为数字型,是NaN返回true,不是返回false

        // window 自带的isNaN 方法,传统的全局方法isNaN()
        let num1 = isNaN(100);
        let num2 = isNaN(NaN);
        let num3 = isNaN("ich");
        let num4 = isNaN("100");

        console.log(num1); // false
        console.log(num2); // true
        // 尝试转换成数值,不成功,返回true
        console.log(num3); // true
        // 尝试转换成数值,成功,返回false
        console.log(num4); // false

        // 新特性的全局方法 isNaN()
        let num5 = Number.isNaN(100);
        let num6 = Number.isNaN(NaN);
        let num7 = Number.isNaN("ich");
        let num8 = Number.isNaN("100");

        console.log(num5); // false

        // Number.isNaN()只有对于NaN才返回true,非NaN一律返回false
        console.log(num6); // true
        console.log(num7); // false

        console.log(num8); // false
    </script>
</body>

</html>

新特性:减少全局性方法,使得语言逐步模块化

新特性的 Number.isFinite() 和 Number.isNaN() 与传统的全局方法 isFinite() 和 isNaN() 的区别在于传统方法先调用 Number() 将非数值的值转为数值,再进行判断,而这两个新方法只对数值有效,Number.isFinite() 对于非数值一律返回false,Number.isNaN() 只有对于NaN才返回true,非NaN一律返回false

6.3 isInteger方法

用来判断一个数值是否为整数

JavaScript 内部,整数和浮点数采用的是同样的储存方法,因此 1 与 1.0 被视为相同的值

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>isInteger 方法</title>
</head>

<body>
    <script>
        let num1 = Number.isInteger(100);
        // 100.0 也算整数
        let num2 = Number.isInteger(100.0);
        // 100.1 就不是整数了
        let num3 = Number.isInteger(100.1);
        let num4 = Number.isInteger("ich");
        let num5 = Number.isInteger("100");

        console.log(num1); // true
        console.log(num2); // true
        console.log(num3); // false
        console.log(num4); // false
        console.log(num5); // false
    </script>
</body>

</html>

6.4 极小常量Number.EPSILON

表示 1 与大于 1 的最小浮点数之间的差

2.220446049250313e-16

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>极小常量 Number.EPSILON</title>
</head>

<body>
    <script>
        function isEqual(a, b) {
            return Math.abs(a - b) < Number.EPSILON
        }

        console.log(isEqual(0.1 + 0.2, 0.3)) //true
        console.log(0.1 + 0.2 === 0.3) //false
    </script>
</body>

</html>

在这里插入图片描述

6.5 Math.trunc

Math.trunc:用于返回数字的整数部分

将小数部分抹掉,返回一个整数

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Math.trunc</title>
</head>

<body>
    <script>
        // 将小数部分抹掉,返回一个整数
        console.log(Math.trunc(1.2)); // 1
        console.log(Math.trunc(1.8)); // 1
        console.log(Math.trunc(-1.8)); // -1
        console.log(Math.trunc(-1.2)); // -1
    </script>
</body>

</html>

6.6 Math.sign

Math.sign方法用来判断一个数到底是正数、负数、还是零

对于非数值,会先将其转换为数值

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Math.sign</title>
</head>

<body>
    <script>
        // Math.sign 方法用来判断一个数到底是正数、负数、还是零
        // 对于非数值,会先将其转换为数值

        console.log(Math.sign(-100)); // -1
        console.log(Math.sign(100)); // +1
        console.log(Math.sign(0)); // +0
        console.log(Math.sign(-0)); // -0
        console.log(Math.sign("ich")); // NaN
    </script>
</body>

</html>

7. 数组扩展

7.1 扩展运算符

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>扩展运算符</title>
</head>

<body>
    <script>
        // ... 展开
        let arr = [1, 2, 3];

        // 传统复制数组
        let arr2 = arr.concat();
        console.log(arr, arr2); // [1, 2, 3] [1, 2, 3]
        arr2.pop();
        console.log(arr, arr2); // [1, 2, 3] [1, 2]

        // 扩展运算符 复制数组
        let arr3 = [...arr];
        console.log(arr, arr3); // [1, 2, 3] [1, 2, 3]

        // 扩展运算符 合并数组
        let arr4 = [4, 5, 6]
        console.log([...arr, ...arr4]); // [1, 2, 3, 4, 5, 6]

        // 扩展运算符与解构赋值的使用
        let myarr = [1, 2, 3, 4, 5, 6, 7, 8];
        let [a, b, c] = myarr;
        console.log(a, b, c); // 1,2,3
        // 只拿到单个值,可以前面 a,b 各取一个数值,剩下的全赋值给 c
        let [a1, b1, ...c1] = myarr;
        console.log(a1, b1, c1);
    </script>
</body>

</html>

7.2 Array.from

将类数组对象转换为真正数组

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Array.from</title>
</head>

<body>
    <ul>
        <li>111</li>
        <li>222</li>
        <li>333</li>
    </ul>
    <script>
        // Array.from

        // 可以将 arguments伪数组 转成真的的数组
        function test() {
            console.log(Array.from(arguments));
        }
        test(1, 2, 3, 4);

        // 获取全部的 li 标签列表,类似数组的对象
        let lis = document.querySelectorAll('li');
        console.log(lis); // 不是真正的数组

        // 可以使用 map 等方法
        Array.from(lis).map(function() {

        })
    </script>
</body>

</html>

将 arguments伪数组 转成真的的数组

在这里插入图片描述

7.3 Array.of

将一组值转化为数组,即新建数组

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Array.of</title>
</head>

<body>
    <script>
        // 下面代码短板是只有一个数值时,会创建一个长度为 3 的数组,
        // 而不是 1 个长度的数组,里面有一个数值 3
        let arr1 = Array(3); 

        // Array.of 弥补该短板
        let arr2 = Array.of(3);

        console.log(arr1, arr2);
    </script>
</body>

</html>

在这里插入图片描述

7.4 find方法

  1. 该方法主要应用于查找第一个符合条件的数组元素

  2. 它的参数是一个回调函数。在回调函数中可以写你要查找元素的条件,当条件成立为true时,返回该元素。如果没有符合条件的元素,返回值为undefined

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>find 方法</title>
</head>

<body>
    <script>
        let arr = [11, 12, 13, 14, 15, 16];

        // 找到比 13 大的数
        let res = arr.find(function (item) {
            return item > 13;
        })
        console.log(res); // 14

        // 查找比 13 大的数,返回该索引
        let res1 = arr.findIndex(function (item) {
            return item > 13;   
        })
        console.log(res1); // 3

        // ES2022 ES13 的 findLast findLastIndex
        // findLast 从最后一个查找比 13 大的数
        let res2 = arr.findLast(function (item) {
            return item > 13;
        })
        console.log(res2); // 16

        // 从最后一个查找比 13 大的数,返回该索引
        let res3 = arr.findLastIndex(function (item) {
            return item > 13;
        })
        console.log(res3); // 5
    </script>
</body>

</html>

7.5 fill 方法

使用自己想要的参数替换原数组内容,但是会改变原来的数组

  • array.fill( value , start , end )
    • value 用来填充数组元素的值,必填
    • start 可选 起始索引,默认值为 0
    • end 可选 终止索引,默认值为 this.length
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>fill 方法</title>
</head>

<body>
    <script>
        // fill 快速填充
        // array.fill( value , start , end )
        // value 用来填充数组元素的值,必填
        // start 可选 起始索引,默认值为 0
        // end 可选 终止索引,默认值为 this.length
        let arr = new Array(3).fill('ichdu');
        console.log(arr);

        let arr1 = [11, 22, 33];
        console.log(arr1.fill("ich", 1, 2));
    </script>
</body>

</html>

在这里插入图片描述

7.6 flat与flatMap方法

flat() 方法可以将多维数组展平成一维数组

flatMap() 方法按照一个可指定的深度递归遍历数组,并将所有元素与遍历到的子数组中的元素合并为一个新数组返回

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>flat 与 flatMap 方法</title>
</head>

<body>
    <script>
        let arr = [1, 2, 3, [4, 5, 6]];
        let arr1 = arr.flat();
        console.log(arr, arr1);
        // arr :1, 2, 3, [4, 5, 6] arr1 : 1, 2, 3, 4, 5, 6

        var arr2 = [
            ["鞍山", "安庆", "安阳"],
            ["北京", "保定", "包头"]
        ]
        console.log(arr2.flat());

        var obj = [
            {
                name: "A",
                list: ["鞍山", "安庆", "安阳"]
            },
            {
                name: "B",
                list: ["北京", "保定", "包头"]
            }
        ]
        console.log(obj.flat());
        // 设置回调函数,返回的是传入的参数的 list 属性
        console.log(obj.flatMap(item => item.list)) 
    </script>
</body>

</html>

在这里插入图片描述

8. 对象扩展

8.1 对象简写

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>对象简写</title>
</head>

<body>
    <script>
        // 创建对象传统写法
        let name = "ich";
        let obj = {
            name: name,
            test: function () {

            },
            test2: function () {

            }
        }

        // 对象简写
        let name1 = "du";
        let obj1 = {
            name, // 相当于 name: name,
            test() {

            },
            test2() {

            }
        }
    </script>
</body>

</html>

8.2 属性名表达式

ES6允许用表达式作为属性名,但是一定要将表达式放在方括号内

注意点:属性的简洁表示法和属性名表达式不能同时使用,否则会报错

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>属性名表达式</title>
</head>

<body>
    <script>
        // 属性名表达式
        // 给属性名起名
        let name1 = "a";
        let obj1 = {
            [name1]: "ich", // 相当于 a: "ich",
            test() { },
            test2() { }
        }
        console.log(obj1); // {a: 'ich', test: ƒ, test2: ƒ}

        let name2 = "a";
        let obj2 = {
            [name2 + "bc"]: "ich", // 相当于 abc: "ich",
            test() { },
            test2() { }
        }
        console.log(obj2); // {abc: 'ich', test: ƒ, test2: ƒ}


        let name3 = "a";
        let name4 = "xxx";
        let obj3 = {
            [name2 + "bc"]: "ich", // 相当于 abc: "ich",
            [name4 + "test"]() { },
            [name4 + "test2"]() { }
        }
        console.log(obj3); // {abc: 'ich', xxxtest: ƒ, xxxtest2: ƒ}
    </script>
</body>

</html>

在这里插入图片描述

8.3 Object.assign

Object.assign(target, object1, object2, …)

用于将源对象的所有可枚举属性复制到目标对象中

第一个参数是目标对象,后面可以跟一个或多个源对象作为参数

  • target:参数合并后存放的对象
  • object1:参数1
  • object2:参数2

如果目标对象和源对象有同名属性,或者多个源对象有同名属性,则后面的属性会覆盖前面的属性

如果该函数只有一个参数,当参数为对象时,直接返回该对象;当参数不是对象时,会先将参数转为对象然后返回

因为 null 和 undefined 不能转化为对象,所以会报错

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Object.assign</title>
</head>

<body>
    <script>
        // ES6 快速合并对象
        let obj1 = {
            name: "ich"
        }
        let obj2 = {
            age: 100
        }
        let obj3 = {
            name: "ichdu"
        }
        console.log(Object.assign(obj1, obj2, obj3)); // {name: 'ichdu', age: 100}
        // 缺点是会改变 obj1 对象
        // 其实是将 obj2、obj3 合并到 obj1,obj2、obj3不会受到变化

        // 不想改变obj1的解决方法:创建一个空的对象
        let obj = {}
        console.log(Object.assign(obj, obj1, obj2, obj3)); // {name: 'ichdu', age: 100}

        // 扩展运算符...对对象的操作 快速复制对象、合并对象 ES2018
        // 快速复制对象
        let obj4 = {
            name: "ich"
        }
        // 复制 obj4 给 obj5
        let obj5 = {
            ...obj4
        }
        console.log(obj5); // {name: 'ich'}
        obj5.name = "du";
        console.log(obj4); // {name: 'ich'} - 没有被更改到 name
        console.log(obj5); // {name: 'du'} - 被更改 name

        // 合并对象
        let obj6 = {
            name: "ich"
        }
        let obj7 = {
            age: 100
        }
        let obj8 = {
            name: "ichdu"
        }
        console.log({ ...obj6, ...obj7 }); // {name: 'ich', age: 100}
        // 合并的对象有重名属性,后合并的对象属性会覆盖前对象属性
        console.log({ ...obj6, ...obj7, ...obj8 }); // {name: 'ichdu', age: 100}
    </script>
</body>

</html>

在这里插入图片描述

8.4 Object.is

方法判断两个值是否是相同的值

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Object.is</title>
</head>

<body>
    <script>
        // Object.is 方法判断两个值是否是相同的值

        //  == 和 === 都可以判断两个值是否是相同的值,
        // 但有个弊端就是无法判断两个 NaN 为 true
        console.log(NaN == NaN); // false
        console.log(NaN === NaN); // false

        console.log(Object.is(5, 5)); // true
        console.log(Object.is(5, "5")); // false
        console.log(Object.is({}, {})); // false
        console.log(Object.is(NaN, NaN)); // true

        // 用处,转换值错误时可以判断NaN
        console.log(Object.is(parseInt("ich"), NaN)); // true

        // 还可以判断 +0 -0 相不相等
        console.log(Object.is(+0, -0)); // false
        console.log(+0 === -0); // true
    </script>
</body>

</html>

9. 函数扩展

9.1 函数传递参数的时候的默认值

  • 在定义函数的时候,有时需要一个默认值出现
  • 当不传递参数的时候,使用默认值,传递参数了就使用传递的参数
  • 注意点:使用函数默认参数时,不允许有同名参数
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>参数默认值</title>
</head>

<body>
    <script>
        // 参数默认值
        function ajax(url, method, async) {
            console.log(url, method, async);
        }
        // 多次调用函数,且参数相同 - 麻烦
        ajax("/aaa", "get", true);
        ajax("/aaa", "get", true);
        ajax("/aaa", "get", true);
        ajax("/aaa", "get", true);

        // 可以使用参数默认值
        function ajax1(url, method = "get", async = true) {
            console.log(url, method, async);
        }
        ajax1("/aaa");
        ajax1("/aaa");
        ajax1("/aaa");
        ajax1("/aaa");
    </script>
</body>

</html>

在这里插入图片描述

9.2 rest 参数

  • rest 参数,剩余参数
    • rest 参数用来表示不确定参数个数
    • 形如,…变量名,由 …加上一个具体变量名参数标识符组成
    • 具体变量名参数只能放在参数组的最后,并且有且只有一个不定参数
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>rest 参数</title>
</head>

<body>
    <script>
        // rest 参数 剩余参数
        function test(data) {
            console.log(data);
        }
        test(1, 2, 3, 4, 5, 6); // 1
        // 获得的是一个参数,因为形参只有一个

        // 如何接收全部的参数
        function test1(...data) {
            console.log(data);
        }
        test1(1, 2, 3, 4, 5, 6); // 打印一个数组 [1, 2, 3, 4, 5, 6]

        // a,b传入相应参数,剩余参数传给 data
        function test2(a, b, ...data) {
            console.log(data);
        }
        test2(1, 2, 3, 4, 5, 6); // [3, 4, 5, 6]

        // name 属性,获得函数名字属性
        console.log(test.name);
    </script>
</body>

</html>

在这里插入图片描述

9.3 箭头函数

  • 箭头函数是 ES6 里面一个简写函数的语法方式
  • 重点: 箭头函数只能简写函数表达式,不能简写声明式函数
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>箭头函数</title>
</head>

<body>
    <ul>
    </ul>
    <script>
        // 箭头函数:写法简洁

        // 传统
        let test = function () {
            console.log("111"); // 111
        }
        test();

        // 箭头函数
        let test2 = () => {
            console.log("222"); // 222
        }
        test2();

        // 更简洁
        let test3 = () => "333";
        console.log(test3());; // 333

        let arr = ["aaa", "bbb", "ccc"];
        let newarr = arr.map((item) => {
            return `<li>${item}</li>`
        });
        console.log(newarr);

    </script>
</body>

</html>

在这里插入图片描述

9.4 箭头函数的特殊性

1

函数体只有一行代码的时候,可以不写 {} ,并且会自动 return

只有return 一条语句时,可以省略 return

如果返回对象需要注意省略格式

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>箭头函数的特殊性</title>
</head>
<body>
    <script>
    	let arr = ["aaa", "bbb", "ccc"];
        // 函数体只有一行代码的时候,可以不写 `{}` ,并且会自动 return
        // 1. 只有return 一条语句时,可以省略 return
        let newarr1 = arr.map((item) => `<li>${item}</li>`);
        console.log(newarr1);

        // 2. 如果返回对象需要注意省略格式
        let test4 = () => {
            return {
                name: "ich",
                age: 100
            }
        }
        console.log(test4()); // {name: 'ich', age: 100}
        // 省略注意 不要省略(),不然只有{},系统识别不出
        // let test5 = () => {
        //     name: "ich",
        //     age: 100
        // }
        let test5 = () => ({
            name: "ich",
            age: 100
        })
        console.log(test5()); // {name: 'ich', age: 100}
    </script>
</body>
</html>

在这里插入图片描述

2

函数的行参只有一个的时候可以不写 () 其余情况必须写

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>箭头函数的特殊性</title>
</head>
<body>
    <script>
        // 函数的行参只有一个的时候可以不写 `()` 其余情况必须写
        // 3. 如果只有一个参数,可以省略包裹参数的()
        let arr1 = ["aaa", "bbb", "ccc"];
        let newarr2 = arr1.map(item => `<li>${item}</li>`);
        console.log(newarr2); //  ['<li>aaa</li>', '<li>bbb</li>', '<li>ccc</li>']

        let arr2 = ["aaa", "bbb", "ccc"];
        let newarr3 = arr2.map((item, index) => `<li>${item}</li>`);
        console.log(newarr3); //  ['<li>aaa</li>', '<li>bbb</li>', '<li>ccc</li>']
    </script>
</body>
</html>

在这里插入图片描述

3. 箭头函数内部没有 arguments

箭头函数内部没有 arguments 这个参数集合

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>箭头函数的特殊性</title>
</head>
<body>
    <script>
        // 箭头函数内部没有 arguments 这个参数集合
        // 无法访问 arguments
        let test6 = () => {
            console.log(arguments);
        }
        test6(1, 2, 3, 4, 5);
        // 报错:Uncaught ReferenceError: arguments is not defined
    </script>
</body>
</html>

在这里插入图片描述

4. 无法 new 实例化

无法 new 实例化

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>箭头函数的特殊性</title>
</head>

<body>
    <script>
        // 5.无法 new 实例化
        let test7 = () => {
            console.log("111");
        };
        new test7();
        // 报错:Uncaught TypeError: test7 is not a constructor
    </script>
</body>

</html>

在这里插入图片描述

5. 箭头函数内部没有 this

箭头函数内部没有 this,箭头函数的 this 是上下文的 this

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>箭头函数的特殊性</title>
</head>

<body>
    模糊搜索
    <input type="text" id="mysearch"><br>
    模糊搜索改进
    <input type="text" id="mysearch1"><br>
    模糊搜索箭头函数
    <input type="text" id="mysearch2"><br>
    模糊搜索箭头函数缺点
    <input type="text" id="mysearch3">
    <script>
        let osearch = document.querySelector("#mysearch");

        // 传统函数的事件
        osearch.oninput = function () {
            setTimeout(function () {
                console.log(this); // Window,指向的事window
                console.log(`发送${this.value}到后端,获取列表数据`);
            }, 1000);
        }
        // 发现发送的都是 undefined 的数据,而不是输入的正常值
        // 因为 this 指向问题,谁调用,this 就指向谁
        // 定时器是内置函数,window调用的,指向的是window下的this,
        // 但是window没有this.value,所以出现 undefined
        // 
        // 改进
        // 将 osearch1.oninput 的 this 赋值给 自定义一个变量
        // 用来存储 osearch1.oninput 的 this
        // 再给定时器调用就可以了
        let osearch1 = document.querySelector("#mysearch1");
        osearch1.oninput = function () {
            let _this = this;
            setTimeout(function () {
                console.log(`发送${_this.value}到后端,获取列表数据`);
            }, 1000);
        }

        // 箭头函数
        let osearch2 = document.querySelector("#mysearch2");
        osearch2.oninput = () => {
            setTimeout(function () {
                // 箭头函数内部没有 this,箭头函数的 this 是上下文的 this
                console.log(`发送${this.value}到后端,获取列表数据`);
            }, 1000);
        }

        // 箭头函数没有this的缺点
        let osearch3 = document.querySelector("#mysearch3");
        osearch3.oninput = () => {
            console.log(this); // this 指向 Window 
            console.log(this.value); // this的value值变成了 undefined
            setTimeout(function () {
                // 因为定时器的 this 指向 父级的,
                // 父级的 this 是 undefined
                // 所以定时器的this的value值也变成undefined
                // 所以使用箭头函数没有this的特性要谨慎
                console.log(`发送${this.value}到后端,获取列表数据`);
            }, 1000);
        }
    </script>
</body>

</html>

在这里插入图片描述


在这里插入图片描述

GitHub代码
gitee代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/540541.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2023年湖北安全员C证C3学历不够可以报考吗 ?个人如何报考?

2023年湖北安全员C证C3学历不够可以报考吗 &#xff1f;个人如何报考&#xff1f; 2023年建筑施工企业三类人员住建厅安全员C证报考是有一定要求的&#xff0c;很多人条件达不到是不是就不能报考&#xff0c;个人想要报考建筑安全员C证怎么去报名等一系列问题。其实都是可以解决…

云渲染与本地渲染:哪个最好?

我们过去曾指出&#xff0c;本地渲染动画和电影的 2D 或 3D 项目是一个非常耗时且计算密集型的过程。当在场景中使用未优化的几何体或在最终渲染中使用多多边形模型时&#xff0c;诸如此类的变量最终将增加完成单个渲染所需的时间和处理器能力。 为什么渲染需要这么长时间&…

keepalived搭建配置

首先&#xff0c;在搞keepalived的时候&#xff0c;一般都是一主一备&#xff0c;所以需要2台设备。这两台设备&#xff0c;要一致&#xff0c;我之前是用了一台centos&#xff0c;一台ubuntu&#xff0c;然后&#xff0c;搞完以后发现&#xff0c;不管是主还是备都持有vip&…

108.(cesium篇)cesium初始定位动画

听老人家说:多看美女会长寿 地图之家总目录(订阅之前建议先查看该博客) 文章末尾处提供保证可运行完整代码包,运行如有问题,可“私信”博主。 效果如下所示: 下面献上完整代码,代码重要位置会做相应解释 <html lang="en"> <

大学生社团管理系统的设计与实现(论文+源码)_kaic

在网络迅速发展的时代&#xff0c;众多软件被开发出来&#xff0c;给社团的管理带了极大的便利&#xff0c;而学生随着时代的发展越来越最求更加个性化的需求。以此&#xff0c;现在的社团管理以学生为导向&#xff0c;根据学生的需求开发一个适合现代化的大学生社团管理系统&a…

Pytest技巧大揭秘:编写高质量接口自动化测试

目录 前言&#xff1a; 一、Pytest测试框架简介 二、安装Pytest测试框架 三、编写Pytest测试用例 四、Pytest参数化&#xff08;Parameterization&#xff09; 五、Pytest插件的使用 六、总结 前言&#xff1a; 在软件开发中&#xff0c;接口的测试是非常重要的一环。接…

Linux服务器安装MYSQL

安装MYSQL 涉及到的工具及软件连接 链接&#xff1a;https://pan.baidu.com/s/1r577kFeuojUrMoEUn88B8w 提取码&#xff1a;xh93 查看是否已经安装了mariadb 检查linux是否安装了mariadb数据库&#xff0c;mariadb数据库是mysql的分支。是免费开源的。mariadb和msyql会有冲突…

准备半个月,面试5分钟不到就凉了,问的实在太····

从外包出来&#xff0c;没想到竟然死在了另一家厂子 自从加入这家公司&#xff0c;每天都在加班&#xff0c;钱倒是给的不少&#xff0c;所以我也就忍了。没想到12月一纸通知&#xff0c;所有人都不许加班&#xff0c;薪资直降30%&#xff0c;顿时有吃不起饭的赶脚。 好在有个…

django ORM框架(操作数据库)第一章

目录 一、ORM框架介绍 二、Django配置数据库 2.1 在本地mysql中创建数据库与用户 2.2 django 连接本地mysql(安装mysqlclient及依赖环境&#xff09;mac安装 三、模型类 3.1、创建模型类&生成迁移脚本&执行迁移脚本 3.2 类属性&表字段介绍 3.2.1 models.Ch…

惊人!2022年我国游戏直播用户规模高达3.82亿人,市场规模1108亿元

随着人们生活水平的提高&#xff0c;人们对娱乐和文化活动的需求也在日益增加&#xff0c;而互联网的快速发展便捷地提供了各种各样丰富多彩的文化和娱乐&#xff0c;也为电子竞技提供了线上直播观看功能&#xff0c;游戏直播逐渐成为社会重要的文化之一。 近年来&#xff0c;…

如何恢复被删除的文件?文件恢复,4招解决!

案例&#xff1a;如何恢复被删除的文件&#xff1f; 【我的一些非常重要的文件保存在电脑中&#xff0c;刚刚一不小心被我删除了&#xff01;请问大家有什么比较可行的被删文件恢复方法吗&#xff1f;】 文件被误删了无法找回会给我们造成很多不便&#xff0c;尤其是重要的文…

JVM 垃圾回收器

GC 分类与性能指标 垃圾收集器概述: 垃圾收集器没有规范中进行过多的规定&#xff0c;可以由不同的厂商、不同版本的 JVM 来实现由于 JDK 的版本处于高速迭代过程中&#xff0c;因此 Java 发展至今已经衍生了众多的 GC 版本从不同角度分析垃圾收集器&#xff0c;可以将 GC 分…

基于语音芯片NV080C方案制作的血氧仪为何实用

随着现代生活水平的提高&#xff0c;人们越来越注重自身的健康状况&#xff0c;而检测血氧和心率数据&#xff0c;成为人们更加重视的健康检测手段之一。血糖仪作为现代化的健康工具&#xff0c;它可以帮助人们更好地了解自己的血糖水平。为方便使用&#xff0c;在血糖仪中加入…

渗透测试--6.1.aircrack-ng破解wifi密码

目录 1.Aircrack-ng简介 1.1 airdump-ng 1.2 aireplay-ng 1.3 aircrack-ng 2.Deauth攻击 3.aircrack-ng工具破解无线网络密码 步骤一&#xff1a;虚拟机连接实验需要用到的网卡 步骤二&#xff1a;设置网卡为监听模式 步骤三&#xff1a;使用wlan0mon网卡扫描附近wif…

Cinema 4D的最佳渲染引擎有哪些?

Cinema 4D是一款专业的3D建模、动画、模拟和渲染软件解决方案。其快速、强大、灵活和稳定的工具集使设计、动态图形、VFX、AR/MR/VR、游戏开发和所有类型的可视化专业人士更容易和高效地使用3D工作流程。除了Cinema 4D附带的标准/物理渲染引擎之外&#xff0c;还有许多用于C4D和…

Android实例——拼图游戏

拼图游戏 项目简介权限adapterPictureListAdapterPuzzleAdapter beanItemBean PresenterIPuzzlePresenterPuzzlePresenterImpl uiIGameCallback utilsConstantImagesUtilsScreenUtils ViewMainActivityPuzzleActivity 布局activity_main.xmlactivity_puzzle.xml 项目简介 选择…

国内 无需科学上网 免费体验 ai 语言交互平台 chatpgt替代(汇总)

ChitGPT CSDN 基于chatgpt 3.5模型 ChitGPT AI EDU - Learn AI, Use AI https://ai.aigcfun.com/ 之前有web端的 现在只有app 和桌面端 通义千问 阿里 通义千问 还没通过审核 360 智脑 360 智脑 体验名额满了 sparkDesk 讯飞 sparkDesk 还没通过审核 文心一言 百度…

行业分析| 快对讲-融合会议的应用

全球经济一体化不断加快&#xff0c;企业也开始注重信息化和现代化建设&#xff0c;无论是企业内部还是外部的沟通与协作都变得非常重要。融合会议为企业提供一种“轻模式”的信息沟通和管理服务。支持语音、视频和数据多媒体通信&#xff0c;实现了语音与数据的无缝融合。用户…

直播预告 | 员工在公司体验感UP,原因竟然是这个......

而随着企业数字化进程的加速&#xff0c;企业账号管理面临着前所未有的挑战。安全性、便捷性和管理效率成为企业管理者关注的重点。 作为公司员工&#xff0c;“打工人”或多或少都面临着不同系统&#xff1a;开发工具、版本控制系统、文档管理系统、项目管理工具......“打工…

LeetCode 637. 二叉树的层平均值

637. 二叉树的层平均值 描述 给定一个非空二叉树的根节点 root , 以数组的形式返回每一层节点的平均值。与实际答案相差 1 0 − 5 10^-\\^5 10−5 以内的答案可以被接受。 示例 示例1 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;[[3],[9,20],[15,7]…