网站建设合同补充内容,物流网站建设方案范文,网络监控软件,wordpress更换网站logo1 -函数作用域问题-:
函数的外层作用域#xff0c;在函数创建时就已确定#xff0c;和函数的调用位置无关
var name 嘿嘿;// 函数的外层作用域#xff0c;在函数创建时就已确定#xff0c;和函数的调用位置无关// JS中的作用域被称为 词法作用域function fn() {console.…1 -函数作用域问题-:
函数的外层作用域在函数创建时就已确定和函数的调用位置无关
var name 嘿嘿;// 函数的外层作用域在函数创建时就已确定和函数的调用位置无关// JS中的作用域被称为 词法作用域function fn() {console.log(name);}function fn2() {var name 哈哈;fn();}fn2();//调用后-输出-嘿嘿
2 数组的其中几种方法1:
var arr [孙悟空, 猪八戒, 沙和尚, 唐僧];// console.log(arr[arr.length - 1]);// Array.isArray() 用来检查一个对象是否是一个数组// console.log(Array.isArray(arr));// console.log(Array.isArray(1));/*//---会影响到原数组的方法:pop()删除并返回数组的最后一个元素。push()在数组的末尾增加一个或多个元素并返回数组的新长度。arr[arr.length] xxx;shift()删除并返回数组的第一个元素。unshift()在数组的开头增加一个或多个元素并返回数组的新长度。*/arr [孙悟空, 猪八戒, 沙和尚, 唐僧];var result arr.pop();//删除数组中的最后一个元素result arr.push(白骨精,玉兔精);result arr.shift();result arr.shift();result arr.unshift(铁扇公主,女儿国王);// result arr.unshift(女儿国王);console.log(result , result);console.log(arr); 3:数组的方法2:
//---不会影响原数组的方法:var arr [孙悟空, 猪八戒, 沙和尚, 唐僧];var arr2 [牛魔王,红孩儿,铁扇];var arr3 [二郎神, 白龙马];/*concat()- 用来将多个数组连接为一个数组- 该方法不会影响到原数组而是将结果存储到一个新数组中返回join()- 将数组中的所有元素连接为一个字符串- 需要一个字符串作为参数这个字符串会作为元素的连接符- 如果不知道参数默认使用,作为连接符indexOf()lastIndexOf()- 查询元素在数组中第一次出现的位置- 参数第一个要查询的元素第二个查询的起始位置- 返回值如果找到了元素则返回元素第一次出现的索引如果没有找到元素则返回-1- lastIndexOf()它会从最后一个元素向前找*/var result arr.concat(arr2, arr3, 哈哈);arr [a,b,c,d];result arr.join();//a,b,c,darr [a,c,b,d,e,f,a,a];result arr.indexOf(g, 1);result arr.lastIndexOf(a);console.log(result);
4 :数组的方法3:
/*slice(起始位置, 结束位置)- 抽取当前数组中的一段元素组合成一个新数组。- 该方法不会影响到原来的数组而是返回一个新数组- 参数第一个参数截取的开始位置包括开始位置第二个参数截取的结束位置不包括结束位置- 如果省略第二个参数则会一直截取最后- 如果索引是负数则表示倒数第几个*/var arr [孙悟空, 猪八戒, 沙和尚, 唐僧];var result arr.splice(1,3);result arr.slice(-4,-1);// console.log(result);/*splice()在任意的位置给数组添加或删除任意个元素。- 该方法是一个破坏性的方法调用会会影响到原来的数组- 参数第一个参数表示删除的起始位置第二个参数表示删除元素的个数第三个参数表示要添加的新元素- 返回值被删除的元素- 功能- 删除并返回指定元素arr.splice(开始索引, 删除数量);- 替换元素arr.splice(开始索引, 删除数量, 新元素, 新元素);- 在指定位置插入新元素arr.splice(插入位置, 0, 新元素, 新元素)*/arr [孙悟空, 猪八戒, 沙和尚, 唐僧];result arr.splice(1,0,牛魔王, 红孩儿);console.log(result)console.log(arr);
5 数组遍历方法4:
forEach() 也是用来遍历数组的一个方法只适用于数组
- 需要一个回到函数作为参数
- 回调函数会执行多次数组里有几个元素就会执行几次
每次调用时都会将一个元素的信息已参数的形式传递进函数
可以通过定义参数来获取信息
- 回调函数中一共会接收到三个参数
第一个参数当前元素的值
第二个参数当前元素的索引
第三个参数被遍历的数组 var arr [孙悟空, 猪八戒, 沙和尚, 唐僧];// arr.forEach(function (value, index, arr) {// console.log(value, index, arr);// });arr.forEach(((value, index, array) console.log(value)));
6:数组去重的2种方法:
多种方式-》
1.遍历删除重复元素
2.遍历添加不重复的元素生成新数组
3.用 ES6的set 方法去重
var nums [1,2,2,3,4,5,5,5,4,5,6];//获取到数组中的每一个数for(var i0; inums.length; i){//nums[i] 表示当前取出的数字//要将该数字和其他数字进行比较//获取到当前数字后的所有数字for(var ji1; jnums.length; j){//nums[i] nums[j]// 比较两个数是否相等if(nums[i] nums[j]){//两个数字相等说明有重复的情况出现删除重复数字nums.splice(j, 1); // j去除新数组中的重复内容,从一开始往后的所有.//删除元素后其后的元素会自动向前补位这样将会导致少比较一个元素//需要将当前的位置在比较一遍j--;}}}console.log(nums);nums [1,2,2,3,4,5,5,5,4,5,6];//先创建一个新数组var newNums [];//遍历老数组for(var i0; inums.length; i){//判断新数组中是否存在该元素if(newNums.indexOf(nums[i]) -1){// 如果新数组中没有该值则将其添加到新数组中newNums.push(nums[i]);}}console.log(newNums);
7引用函数和接收函数返回值的区别:
function fn(callback) {//调用函数callback();// console.log(callback);}function test() {console.log(test执行了~~~);}// test 表示函数对象以test作为参数时是将函数对象作为参数传递fn(test);test() // 表示调用函数函数执行后会有返回值test()相当于将函数的返回值作为参数传递fn(test());8 数组方法5:
/* every()- 用来检查数组中的每个元素是否符合某个条件如果所有的元素都符合条件它会返回true否则返回false- 它需要一个回调函数作为参数回调函数需要返回一个布尔值如果返回true则表示元素满足条件如果返回false则表示元素不满足条件some()- 用来检查数组中是否有元素符合某个条件*/var arr [3,4,5,6,7,8];var result arr.every(function (ele) {return ele 6;})result arr.every(ele ele6);result arr.some(ele ele6);// console.log(result);/*filter()- 用来获取数组中所有的符合条件的元素*/result arr.filter(a a ! null a%20);/*map()- 用来对数组中的每一个元素做一个操作返回一个新数组*/arr [3,4,5,6,7,8];var result arr.map(function (a) {if(a % 20){return a ** 2;}else{return a;}});/*reduce()- 将数组中的所有元素汇总为一个值- 需要回调函数作为参数参数有两个第一个参数表示累加器第二个参数表示当前元素*/arr [3,4,5,6,7,8];result arr.reduce(function (a, b) {return a b;});console.log(result);//----------// find() 方法返回数组中满足提供的测试函数的第一个元素的值。否则返回 undefined。//在数组每一项上执行的函数接收 3 个参数//element当前遍历到的元素。//index可选当前遍历到的索引。//array可选数组本身。// findIndex()方法返回数组中满足提供的测试函数的第一个元素的索引。否则返回-1。// const array1 [5, 12, 8, 130, 44];const isLargeNumber (element) element 13;console.log(array1.findIndex(isLargeNumber));
针对数组中的每个元素, 都会执行该回调函数, 执行时会自动传入下面三个参数:element当前元素。index当前元素的索引。array调用findIndex的数组。
9数组方法6:
/*reverse()用来对数组进行反转操作- 该方法会影响到原来数组*/var arr [1,2,3,4,5,6,7];arr.reverse();/*sort() 用来对数组进行排序- sort()在排序时默认是安装Unicode编码进行排序的即使你数组中的元素是数字它也是这么做的- 如果希望在按照数字的大小进行排序则可以自己通过回调函数来指定排序规则*/arr [3,1,2,4,5,6,8,9,7,10];// arr [c,d,a,e,f,g];arr [3, 4];/*sort()中的回调函数用来指定元素的排列规则它会被多次调用每次调用时会传递数组两个元素作为参数可以定义两个参数来接收元素两个元素具体是谁不确定但能确定的是a在数组中位于b的后边只适用于新版的Chromesort会根据回调函数的返回值来决定两个元素是否交换位置如果返回的是负值则两个元素会交换位置如果返回的是正值则两个元素的位置不变如果返回0表示两个元素的值的相等位置不变在其他的浏览器中规则和新版的Chrome完全相反但是使用时没有任何区别*/arr [3,1,2,4,5,6,8,9,7,10];// arr.sort(function (a, b) {// //b,a// // // 希望小的数字在前// // if(a b){// // // 后边的数字大于前边的数字// // return 1;// // }else if(a b){// // //两个数字相等// // return 0;// // }else{// // // 后边的数字小// // return -1;// // }////// // 希望大的数字在前// if(a b){// // 后边的数字大于前边的数字// return -1;// }else if(a b){// //两个数字相等// return 0;// }else{// // 后边的数字小// return 1;// }//// });arr.sort(function (a, b) {// 如果返回a-b则表示数字升序排列// return a - b;// 如果返回b-a则表示数字降序排列return b - a;});console.log(arr);// fill() 方法用一个固定值填充一个数组中从起始索引到终止索引内的全部元素。不包括终止索引。const array1 [1, 2, 3, 4];console.log(array1.fill(0, 2, 4));console.log(array1.fill(5, 1));console.log(array1.fill(6));//includes() 方法用来判断一个数组是否包含一个指定的值根据情况如果包含则返回 true否则返回falseconst array1 [1, 2, 3];console.log(array1.includes(2));// trueconst pets [cat, dog, bat];console.log(pets.includes(cat));//trueconsole.log(pets.includes(at)); //false//keys() 方法返回一个包含数组中每个索引键的Array Iterator对象。const array1 [a, b, c];const iterator array1.keys();for (const key of iterator) {console.log(key);} //0, 1,2// reduceRight() 方法接受一个函数作为累加器accumulator和数组的每个值从右到左将其减少为单个值。const array1 [[0, 1], [2, 3], [4, 5]].reduceRight((accumulator, currentValue) accumulator.concat(currentValue));console.log(array1);// expected output: Array [4, 5, 2, 3, 0, 1]// values() 方法返回一个新的 Array Iterator 对象该对象包含数组每个索引的值const array1 [a, b, c];const iterator array1.values();for (const value of iterator) {console.log(value);} //’a’,’b’,’c’ 欢迎关注我的原创文章小伙伴们我是一名热衷于前端开发的作者致力于分享我的知识和经验帮助其他学习前端的小伙伴们。在我的文章中你将会找到大量关于前端开发的精彩内容。
学习前端技术是现代互联网时代中非常重要的一项技能。无论你是想成为一名专业的前端工程师还是仅仅对前端开发感兴趣我的文章将能为你提供宝贵的指导和知识。
在我的文章中你将会学到如何使用HTML、CSS和JavaScript创建精美的网页。我将深入讲解每个语言的基础知识并提供一些实用技巧和最佳实践。无论你是初学者还是有一定经验的开发者我的文章都能够满足你的学习需求。
此外我还会分享一些关于前端开发的最新动态和行业趋势。互联网技术在不断发展新的框架和工具层出不穷。通过我的文章你将会了解到最新的前端技术趋势并了解如何应对这些变化。
我深知学习前端不易因此我将尽力以简洁明了的方式解释复杂的概念并提供一些易于理解的实例和案例。我希望我的文章能够帮助你更快地理解前端开发并提升你的技能。
如果你想了解更多关于前端开发的内容不妨关注我的原创文章。我会不定期更新为你带来最新的前端技术和知识。感谢你的关注和支持我们一起探讨交流技术共同进步期待与你一同探索前端开发的奇妙世界 文章转载自: http://www.morning.rrcrs.cn.gov.cn.rrcrs.cn http://www.morning.knzmb.cn.gov.cn.knzmb.cn http://www.morning.mpszk.cn.gov.cn.mpszk.cn http://www.morning.zdsqb.cn.gov.cn.zdsqb.cn http://www.morning.xkwyk.cn.gov.cn.xkwyk.cn http://www.morning.cwjsz.cn.gov.cn.cwjsz.cn http://www.morning.xcbnc.cn.gov.cn.xcbnc.cn http://www.morning.tzlfc.cn.gov.cn.tzlfc.cn http://www.morning.ykwqz.cn.gov.cn.ykwqz.cn http://www.morning.sqqkr.cn.gov.cn.sqqkr.cn http://www.morning.rmxgk.cn.gov.cn.rmxgk.cn http://www.morning.fbylq.cn.gov.cn.fbylq.cn http://www.morning.qieistand.com.gov.cn.qieistand.com http://www.morning.rrcrs.cn.gov.cn.rrcrs.cn http://www.morning.hyxwh.cn.gov.cn.hyxwh.cn http://www.morning.nlryq.cn.gov.cn.nlryq.cn http://www.morning.bgqr.cn.gov.cn.bgqr.cn http://www.morning.yhljc.cn.gov.cn.yhljc.cn http://www.morning.ccyns.cn.gov.cn.ccyns.cn http://www.morning.zshuhd015.cn.gov.cn.zshuhd015.cn http://www.morning.lpnb.cn.gov.cn.lpnb.cn http://www.morning.ppghc.cn.gov.cn.ppghc.cn http://www.morning.cwfkm.cn.gov.cn.cwfkm.cn http://www.morning.kngqd.cn.gov.cn.kngqd.cn http://www.morning.frxsl.cn.gov.cn.frxsl.cn http://www.morning.xjwtq.cn.gov.cn.xjwtq.cn http://www.morning.jykzy.cn.gov.cn.jykzy.cn http://www.morning.zlnmm.cn.gov.cn.zlnmm.cn http://www.morning.pljxz.cn.gov.cn.pljxz.cn http://www.morning.zycll.cn.gov.cn.zycll.cn http://www.morning.ljygq.cn.gov.cn.ljygq.cn http://www.morning.ljjmr.cn.gov.cn.ljjmr.cn http://www.morning.jgrjj.cn.gov.cn.jgrjj.cn http://www.morning.skbkq.cn.gov.cn.skbkq.cn http://www.morning.gpnfg.cn.gov.cn.gpnfg.cn http://www.morning.skkmz.cn.gov.cn.skkmz.cn http://www.morning.cgntj.cn.gov.cn.cgntj.cn http://www.morning.rqxch.cn.gov.cn.rqxch.cn http://www.morning.xdjwh.cn.gov.cn.xdjwh.cn http://www.morning.rlfr.cn.gov.cn.rlfr.cn http://www.morning.zcnwg.cn.gov.cn.zcnwg.cn http://www.morning.lrmts.cn.gov.cn.lrmts.cn http://www.morning.mqpdl.cn.gov.cn.mqpdl.cn http://www.morning.yfrbn.cn.gov.cn.yfrbn.cn http://www.morning.jspnx.cn.gov.cn.jspnx.cn http://www.morning.hhpkb.cn.gov.cn.hhpkb.cn http://www.morning.trmpj.cn.gov.cn.trmpj.cn http://www.morning.qtyfb.cn.gov.cn.qtyfb.cn http://www.morning.elmtw.cn.gov.cn.elmtw.cn http://www.morning.xykst.cn.gov.cn.xykst.cn http://www.morning.pmftz.cn.gov.cn.pmftz.cn http://www.morning.pdwzr.cn.gov.cn.pdwzr.cn http://www.morning.jcfg.cn.gov.cn.jcfg.cn http://www.morning.fglyb.cn.gov.cn.fglyb.cn http://www.morning.prgrh.cn.gov.cn.prgrh.cn http://www.morning.kaylyea.com.gov.cn.kaylyea.com http://www.morning.rkck.cn.gov.cn.rkck.cn http://www.morning.yghlr.cn.gov.cn.yghlr.cn http://www.morning.fqljq.cn.gov.cn.fqljq.cn http://www.morning.jwcmq.cn.gov.cn.jwcmq.cn http://www.morning.pqyms.cn.gov.cn.pqyms.cn http://www.morning.jrrqs.cn.gov.cn.jrrqs.cn http://www.morning.mjtgt.cn.gov.cn.mjtgt.cn http://www.morning.gzxnj.cn.gov.cn.gzxnj.cn http://www.morning.cwwbm.cn.gov.cn.cwwbm.cn http://www.morning.gbgdm.cn.gov.cn.gbgdm.cn http://www.morning.lbrwm.cn.gov.cn.lbrwm.cn http://www.morning.hhnhb.cn.gov.cn.hhnhb.cn http://www.morning.nwjzc.cn.gov.cn.nwjzc.cn http://www.morning.nyjgm.cn.gov.cn.nyjgm.cn http://www.morning.psgbk.cn.gov.cn.psgbk.cn http://www.morning.dqpd.cn.gov.cn.dqpd.cn http://www.morning.dzgyr.cn.gov.cn.dzgyr.cn http://www.morning.mjyrg.cn.gov.cn.mjyrg.cn http://www.morning.fygbq.cn.gov.cn.fygbq.cn http://www.morning.ybmp.cn.gov.cn.ybmp.cn http://www.morning.cybch.cn.gov.cn.cybch.cn http://www.morning.brwp.cn.gov.cn.brwp.cn http://www.morning.tdgwg.cn.gov.cn.tdgwg.cn http://www.morning.kxwsn.cn.gov.cn.kxwsn.cn