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>
相关推荐
dot.Net安全矩阵4 分钟前
.NET 一款在线解密Web.config的脚本
前端·学习·安全·web安全·oracle·矩阵·.net
虚无火星车6 分钟前
说说停止线程池的执行流程?
java·开发语言
奔跑的代码!7 分钟前
sass实现文字两侧横线
前端·vue·sass
乔以亦8 分钟前
python 装饰器
linux·开发语言·python
GHUIJS11 分钟前
【Echarts】使用多横坐标轴展示近十五天天气预报
javascript·echarts
计算机学姐13 分钟前
基于python+django+vue的社区爱心养老管理系统
开发语言·vue.js·后端·python·mysql·django·web3.py
正小安13 分钟前
使用Nignx打包前端项目
前端·vue.js·nginx·阿里云
V_fanglue370515 分钟前
qmt量化交易策略小白学习笔记第60期【qmt编程之期权数据--基于BS模型计算欧式期权隐含波动率--内置Python】
开发语言·windows·笔记·python·学习·区块链
m87里的光40 分钟前
vue3子组件向父组件传值
javascript·vue.js·elementui
J不A秃V头A41 分钟前
Vue3:el-table实现日期的格式化
javascript·vue.js·elementui