03-JavaScript高阶( 代码)
目录
01-数组的操作方法
02-call,apply,bind方法改变this指向
03- call,apply,bind方法的使用场景
04-constructor判断数据类型
05-create继承
01-数组的操作方法
<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指向
<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方法的使用场景
<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判断数据类型
<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继承
<script>// Object.create() 继承var father = {money: 20000}var son = Object.create(father, {name: {enumerable: true,writable: true,configurable: true,value: "小张"}});console.log(son);</script>