03-JavaScript高阶( 代码)

目录

01-数组的操作方法

02-call,apply,bind方法改变this指向

[03- call,apply,bind方法的使用场景](#03- call,apply,bind方法的使用场景)

04-constructor判断数据类型

05-create继承


01-数组的操作方法

javascript 复制代码
 <script>
        var arr = [1, 2, 3, 2, 4, 5, 5, 1, 6, 7, 8, 9];

        // for (var i = 0; i < arr.length; i++) {
        //     console.log(arr[i]);
        // }

        // 1.forEach() 遍历数组
        // arr.forEach(function (value, index, arr) {
        //     // 遍历的元素
        //     // console.log(value);

        //     // 索引
        //     // console.log(index);

        //     // console.log(arr);
        // });

        // 2.map() 遍历数组
        // var newArr = arr.map(function (value, index, arr) {

        //     // return返回值
        //     return value + "map";
        // });
        // console.log(newArr);

        // 3.filter() 过滤数组
        // var newArr = arr.filter(function (value, index, arr) {
        //     return value % 2 == 0;
        // });
        // console.log(newArr);

        // var data = ["小米14", "iphone 15", "小米12", "huawei Mate60", "huawei P60"];
        // var huawei = data.filter(function (value, index, arr) {
        //     return value.includes("huawei")
        // });
        // console.log(huawei);

        // 4.some() 数组中 是否有满足条件的元素true false; 一旦发现满足条件的元素,后面的将不再被遍历
        // var res = arr.some(function (value, index, arr) {
        //     console.log(value);
        //     return value > 5;
        // });
        // console.log(res);

        // 5.every() 数组中每个元素是否都符合条件; 一旦发现不满足条件的元素,后面的将不再被遍历
        // var res = arr.every(function (value, index, arr) {
        //     console.log(value);
        //     return value < 5;
        // });
        // console.log(res);

        // 6.find() 找一个满足条件的值; 一旦找到符合条件的元素,立即返回,后面不再遍历;找不到返回 undefined
        // var res = arr.find(function (value, index, arr) {
        //     console.log(value);
        //     return value > 5;
        // });
        // console.log(res);

        // 7.reduce() 累加器    total作为上次操作的结果
        // var sum = arr.reduce(function (total, value, index, arr) {
        //     console.log(total);
        //     return total + value;
        // },0)
        // console.log(sum);

        // 数组去重
        // var resArr = arr.reduce(function (total, value) {
        //     console.log(total);
        //     if (total.includes(value)) {
        //         return total;
        //     } else {
        //         total.push(value);
        //         return total;
        //     }
        // }, []);
        // console.log(resArr);

        // 数组元素累乘
        var res = arr.reduce(function (total, value) {
            return total * value;
        }, 1);
        console.log(res);
    </script>

02-call,apply,bind方法改变this指向

javascript 复制代码
     <script>

        var num = 10;
        function fun(a, b) {
            console.log(this);

            // 普通函数 this 指向 window 
            console.log(this.num + a + b);
        }

        var obj = {
            num: 20
        }

        fun(1, 2);

        // Function.prototype.call()
        // call() 改变this 指向,参数以 逗号 分割,会立即调用函数执行
        fun.call(obj, 1, 2);
    </script>


    <script>
        var num = 10;
        function fun(a, b) {
            console.log(this);

            // 普通函数 this 指向 window 
            console.log(this.num + a + b);
        }

        var obj = {
            num: 20
        }

        fun(1, 2);

        // Function.prototype.apply();
        // apply() 改变this 指向,参数以数组形式传递,立即调用函数执行
        fun.apply(obj, [1, 2]);
    </script>


    <script>
        var num = 10;
        function fun(a, b) {
            console.log(this);

            // 普通函数 this 指向 window 
            console.log(this.num + a + b);
        }

        var obj = {
            num: 20
        }

        fun(1, 2);

        // Function.prototype.bind()
        // bind() 改变 this 指向,参数以逗号隔开,不会立即调用函数执行,需要手动调用
        fun.bind(obj, 1, 2)();

        // call()  apply()  bind()
        // 相同点:都可以改变 this 指向
        // 不同点:call() apply()之间,都会立即调用函数执行,call()的参数以逗号分隔,apply()的        参数以数组形式传递
        //        call() bind()之间,参数都以逗号分割,call()会立即调用函数执行,bind()需要手动调用
    </script>

03- call,apply,bind方法的使用场景

javascript 复制代码
     <script>
        // 数据类型的判断

        // 最精准的判断方法
        // Object.prototype.toString.call();

        var obj = {};
        var arr = [];
        var date = new Date();
        var num = 10;

        console.log(Object.prototype.toString.call(obj));   // "[object Object]"
        console.log(Object.prototype.toString.call(arr));   // "[object Array]"
        console.log(Object.prototype.toString.call(date));   // "[object Date]"
        console.log(Object.prototype.toString.call(num));   // "[object Number]"

    </script>

      
    <script>
        // apply() 参数以数组形式传递,立即调用函数执行

        // Math.max() 传入参数的最大值
        console.log(Math.max(2, 3, 5, 7, 1, 7, 9, 0, 4, 7));

        var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];

        // 求数组中的最大值最小值
        console.log(Math.min.apply(Math, arr));
    </script>


    <body>
    <button>点击</button>
    <button>点击</button>
    <button>点击</button>
    <button>点击</button>
    <button>点击</button>
    <script>
        // bind() 不会立即调用函数执行,一般用于改变定时器中的this 指向

        // 循环绑定事件
        var btn = document.querySelectorAll("button");

        for (var i = 0; i < btn.length; i++) {
            btn[i].onclick = function () {
                var time = 5;

                this.disabled = true;

                this.innerHTML = "请" + time + "s之后再次点击";

                this.timeId = setInterval(function () {
                    console.log(this);
                    if (time > 1) {
                        time--;
                        // this 
                        this.innerHTML = "请" + time + "s之后再次点击";
                    } else {
                        // this 
                        this.removeAttribute("disabled");
                        this.innerHTML = "点击";
                        clearInterval(this.timeId)
                    }
                }.bind(this), 1000)
            }
        }
    </script>

04-constructor判断数据类型

javascript 复制代码
 <script>
        var num = 10;

        // console.log(num.constructor);

        console.log(num.constructor == Number);

        var arr = [];
        console.log(arr.constructor == Array);

        // null  undefined 不能用constructor判断数据类型

        // 判断数据类型的方法
        // typeof instanceof Object.prototype.toString.call() constructor
    </script>

05-create继承

javascript 复制代码
<script>
        // Object.create() 继承

        var father = {
            money: 20000
        }

        var son = Object.create(father, {
            name: {
                enumerable: true,
                writable: true,
                configurable: true,
                value: "小张"
            }
        });

        console.log(son);
    </script>
相关推荐
sg_knight几秒前
VSCode如何修改默认扩展路径和用户文件夹目录到D盘
前端·ide·vscode·编辑器·web
云空1 分钟前
《解锁 Python 数据挖掘的奥秘》
开发语言·python·数据挖掘
一个处女座的程序猿O(∩_∩)O10 分钟前
完成第一个 Vue3.2 项目后,这是我的技术总结
前端·vue.js
mubeibeinv10 分钟前
项目搭建+图片(添加+图片)
java·服务器·前端
青莳吖12 分钟前
Java通过Map实现与SQL中的group by相同的逻辑
java·开发语言·sql
逆旅行天涯17 分钟前
【Threejs】从零开始(六)--GUI调试开发3D效果
前端·javascript·3d
Buleall19 分钟前
期末考学C
java·开发语言
重生之绝世牛码21 分钟前
Java设计模式 —— 【结构型模式】外观模式详解
java·大数据·开发语言·设计模式·设计原则·外观模式
小蜗牛慢慢爬行27 分钟前
有关异步场景的 10 大 Spring Boot 面试问题
java·开发语言·网络·spring boot·后端·spring·面试
Algorithm157637 分钟前
云原生相关的 Go 语言工程师技术路线(含博客网址导航)
开发语言·云原生·golang