首页IT科技es6语法菜鸟教程(复习 – es6语法)

es6语法菜鸟教程(复习 – es6语法)

时间2025-08-05 04:03:30分类IT科技浏览5472
导读:这几天电脑有点问题,一直在弄,而且论文也逼近了也在时间弄那个 ,前面node有一个大项目,已经做完了,我现在是准备把上次复习断下的继续复习一直到这个项目,然后就开始vue了。...

这几天电脑有点问题                ,一直在弄                      ,而且论文也逼近了也在时间弄那个         ,前面node有一个大项目            ,已经做完了                      ,我现在是准备把上次复习断下的继续复习一直到这个项目           ,然后就开始vue了              。

1.

首先是函数的一个进阶        ,要明白函数也是对象                       ,所以是可以通过new的方法来创建实例的                        。

然后是调用函数的三个方法:call可以改变this加调用              、apply可以改变this但是传的参数是数组也可以调用                        、bind可以改变this传的参数也跟第一个call一样但是就是不会自己调用        。

2.

今天的主打内容

闭包首先要知道严格模式              ,use srict放在局部或者全局作用域都可以    ,然后有哪些变化                        ,变量必须声明赋值啊        、this普通函数为undefined啊          、函数形参不能重名啊                       、函数生命必须在顶层啊等等            、

高阶函数:就是函数里面嵌套一个函数或者return为一个函数

然后就是闭包                  ,什么事闭包?

闭包就是一个能够访问函数局部变量的函数,两个注意点                    ,一个是函数                      ,一个是访问局部变量          。

还是跟以前一样传一些我第二次做有些感想的案例吧    ,就不全部传上来了                       。第一个是点击li打印索引号通过闭包来做

然后是闭包算价格这个                ,看得出来还有点没有完全吃透闭包的原理

<!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>Document</title> </head> <body> <!-- 打车起步价13(3公里内), 之后每多一公里增加 5块钱. 用户输入公里数就可以计算打车价格 如果有拥堵情况,总价格多收取10块钱拥堵费 --> <script> function getMoney() { let total = 13 let price = 0 return { price : function(n) { // console.log(total, mile); if(n > 3) { price = total + Math.ceil(n - 3) * 5 } else { price = total } return price }, congestionPrice : function(n,congestion) { this.price(n) if (congestion) { price += 10 } else { price = total } return price } } } console.log(getMoney().price(1)); console.log(getMoney().congestionPrice(1,true)); console.log(getMoney().price(4)); console.log(getMoney().congestionPrice(4, true)); </script> </body> </html>

3.

递归

递归就是在函数内部在调用自身                      ,类似于循环        ,通过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>Document</title> </head> <body> <script> // 利用递归函数求1~n的阶乘 1 * 2 * 3 * 4 * ..n function getResult(n) { if (n == 1) { return 1 } return n * getResult(n - 1) } console.log(getResult(3)); </script> </body> </html>

然后斐波拉起亚数列

<!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>Document</title> </head> <body> <script> /* 利用递归函数求斐波那契数列(兔子序列) 1       、1                      、2                、3    、5                      、8                    、13、21... // 用户输入一个数字 n 就可以求出 这个数字对应的兔子序列值 // 我们只需要知道用户输入的n 的前面两项(n-1 n-2)就可以计算出n 对应的序列值 */ function getResult(n) { if (n == 1 || n == 2) { return 1 } return getResult(n - 1) + getResult(n - 2) } console.log(getResult(5)); </script> </body> </html>

这个有一点问题                      ,我明说我没执行出来           ,但是我真的很想知道我错在哪里了        ,原理都摆在这里是没问题的                       ,代码也没问题              ,求大神指教

<!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>Document</title> </head> <body> <script> /* 我们想要做输入id号,就可以返回的数据对象*/ var data = [{ id: 1, name: 家电, goods: [{ id: 11, gname: 冰箱, goods: [{ id: 111, gname: 海尔 }, { id: 112, gname: 美的 }, ] }, { id: 12, gname: 洗衣机 }] }, { id: 2, name: 服饰 }]; var o = {} function getData(arr, id) { arr.forEach(function(item) { if (item.id == id) { o = item return o } else if(item.goods && item.goods.length > 0) { getData(item.goods, id) } }) } console.log(getData(data, 1)); console.log(getData(data, 11)); </script> </body> </html>

说到了递归就顺便说一下浅拷贝和深拷贝       。

浅拷贝就是只拷贝表面的一层    ,深层次的东西就拷贝引用                        ,就是不管你改哪边的数据                  ,双方都会受影响

<!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>Document</title> </head> <body> <script> // 浅拷贝只拷贝一层 更深层次只拷贝引用 也就是你改或者他改值双方都受影响 var obj = { id: 1, name: andy, msg: { age: 18 } } var o = {} for (k in obj) { o[k] = obj[k] } console.log(o); console.log(------------------) // es6快速浅拷贝语法 Object.assign(obj, o) console.log(o); </script> </body> </html>

然后就是深拷贝,深拷贝就是可以单独开辟空间                    ,各管各的                      ,互不影响    ,深拷贝的函数用到了递归                ,这个还是要记一下的

<!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>Document</title> </head> <body> <script> // 深拷贝就是更深层的数据 也会单独开辟空间 比如数组                  、函数等 var obj = { id: 1, name: andy, msg: { age: 18 }, color: [pink, red] } let o = {} function getCopy(usedCopy, useCopy) { for (k in usedCopy) { if (usedCopy[k] instanceof Array) { useCopy[k] = [] getCopy(usedCopy[k], useCopy[k]) } else if (usedCopy[k] instanceof Object) { useCopy[k] = {} getCopy(usedCopy[k], useCopy[k]) } else { useCopy[k] = usedCopy[k] } } } getCopy(obj, o) console.log(o); </script> </body> </html>

4.

接下来是正则表达式                      。

这个其实各种语法我就不多说了                      ,参考mdn                        、菜鸟教程这些多得很        ,我说一下今天的案例有一个替换敏感字符嘛            ,正则里面的规则是中文的话不用写引号                      ,直接写进去就是           ,一个案例邮箱提取        ,说一下exec这个方法怎么来多次调用

<!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>Document</title> </head> <body> <script> /* 将字符串小明:大神么么哒                       ,正好是我想要的              ,我的邮箱是xiaoming@qq.com小红:我老公最爱看这个了    ,我想给他一个惊喜                        ,么么么哒                  , 邮箱是xiaohong@sina.com我:好人一生平安,邮箱是wuyou@163.com中所有的邮箱号码提取出来 */ // 注意 要使用exec进行多次匹配不仅正则要添加全局匹配 而且还有用一个while循环 let str = `小明:大神么么哒                    ,正好是我想要的                      ,我的邮箱是xiaoming@qq.com小红:我老公最爱看这个了    ,我想给他一个惊喜                ,么么么哒                      , 邮箱是xiaohong@sina.com我:好人一生平安        ,邮箱是wuyou@163.com` let reg = /\w+@\w+.[a-zA-z]+/g var result = reg.exec(str) while(result!== null) { console.log(result[0]); result = reg.exec(str) } </script> </body> </html>

正则差不多就这样了

5.

然后是一些es6语法:let    、const              、解构赋值                        、箭头函数                。

其实我一直搞不懂let这个块级作用域到底是限制在哪里            ,我感觉作用域范围跟var一样哪里都可以用                      ,所以我后面基本都用let声明的变量    。当然我这个是错误思想哈           ,我是想以后慢慢通过实例来了解                      。

然后剩余参数也就是扩展运算符三个点        ,然后就是array新增的一些方法        、form可以将维数组或者对象转为数组                       ,第二个参数可以循环对每一个进来的值做操作              ,arr.find可以找满足第一个条件的值    ,没有就返回undefined                        ,参数也是写item\然后对应的findindex就是找

满足第一个条件的参数的下标                  ,还有就是查找数组里面有没有包含这个值.includes

然后就是模板字符串                    。

string页新增了一些方法:str.strtwith endstith看这个字符有没有在这个字符串的开头或结尾。

.repeat可以将字符创重复n次返回一个新数组                  。

最后就是set数据结构因为跟数组相似,通过new 里面的参数可以传数组                    ,又因为自身的没有重复值的特点所以给数组起到一个去重的操作

然后他的一个属性.size可以查看set数据结构有多少值

add方法连式编程的形式新增数据

delete方法删除返回的是布尔值

has查看有无返回布尔值

clear清空数据结构

最后set也可以用forEach进行一个遍历操作

声明:本站所有文章                      ,如无特殊说明或标注    ,均为本站原创发布                        。任何个人或组织                ,在未征得本站同意时                      ,禁止复制          、盗用                       、采集            、发布本站内容到任何网站       、书籍等各类媒体平台    。如若本站内容侵犯了原著者的合法权益        ,可联系我们进行处理              。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
女的在网上挣什么钱最快(网上赚钱方法有哪些-女人靠什么赚钱?分享在家做菜方法也能网上赚钱)