您现在的位置:新闻首页>资本 > javascript中非常实用的10个特性
javascript中非常实用的10个特性
你可能刚上手 JavaScript,或者只是曾经偶尔用过。不管怎样,JavaScript 改变了很多,有些特性非常值得一用。 这篇文章介绍了一些特性,在我看来,一个严肃的 JavaScript 开发者每天都多多少少会用到这些特性。
《JavaScript视频教程》
参考资料
下面两个关于 ES6+ 的站点是我的最爱:
ES6 FeaturesMDN展开操作符
顾名思义,用于对象或数组之前的展开操作符(...),将一个结构展开为列表。 演示一下:
let firstHalf = [ 'one', 'two']; let secondHalf = ['three', 'four', ...firstHalf];
这种写法够优雅,够简洁吧? 如果不用展开操作符,我们得这么写:
let firstHalf = [ 'one', 'two']; let secondHalf = ['three', 'four']; for(var i=0, i <firstHalf.length; i++ ) { secondHalf.push(firstHalf[i]); }
展开操作符也适用于合并对象的属性:
const hero = { name: 'Xena - Warrior Princess', realName: 'Lucy Lawless' } const heroWithSword = { ...hero, weapon: 'sword' }
不用展开操作符的话,需要遍历对象的属性:
let keys = Object.keys(hero); let obj = {}; for(var i=0; i< keys.length; i++) { obj[keys[i]] = keys[props[i]]; }剩余参数
剩余参数将剩余的参数收入数列。 JavaScript 的特性是参数数目很灵活。 通常会有一个 arguments 变量收集参数。 让我们看一个例子:
function add(first, second, ...remaining) { return first + second; }
上面的一段代码仅仅将 first 和 second 加起来,也就是说,调用 add(1, 2) 和 add(1, 2, 3, 4) 会得到相同的结果。 下面我们修正一下:
function add(first, second, ...remaining) { return first + second + remaining.reduce((acc, curr) => acc + curr, 0); }
如前所述,...remaining 收集了剩余的参数,为我们提供了这些参数的命名,清楚地表明我们打算处理剩余的参数。 我记得至迟 ES5 已经有 arguments 了,不过少有人知。
字符串插值
见过这样的语句吗?
当然,我指的是 getDescription() 方法中那个可读性不佳的多行长语句。 大多数编程语言中都存在类似现象。 一些语言提供了字符串插值,幸运的是,JavaScript 正是其中之一。 我们改写一下 getDescription() 方法:
getDescription() { return `Full description \\n: name: ${this.name} description ${this.description} `; }
一对 ` 包起来的字符串中可以使用 ${} 插值。 现在看起来舒服多了。
简写属性
在 ES5 中必须这么写:
function createCoord(x, y) { return { x: x, y: y } }
ES6 以后可以使用简写属性:
function createCoord(x, y) { return { x, y } }
看起来更清爽了吧?
方法属性
方法属性是在对象中定义指向方法的属性。 考虑下面一段 ES5 代码作为例子:
const math = { add: function(a,b) { return a + b; }, sub: function(a,b) { return a - b; }, multiply: function(a,b) { return a * b; } }
ES6 以后只需这么写:
const math = { add(a,b) { return a + b; }, sub(a,b) { return a - b; }, multiply(a,b) { return a * b; } }解构赋值
解构赋值有利于开发者本人的心理健康。
考虑下面的代码:
function handle(req, res) { const name = req.body.name; const description = req.body.description; const url = req.url; log('url endpoint', url); // 大量代码逻辑 dbService.createPerson(name, description) }
不管从什么角度来看,上面的代码都不完美,但它确实体现了一种应用场景,我们想要从对象的不同层次获取数据。 你也许会问,这里有什么问题? 好吧,我可以不用声明这么多变量,省下一些敲击键盘的次数。
function handle(req, res) { const { body: { name, description }, url } = req; log('url endpoint', url); // 大量代码逻辑 dbService.createPerson(name, description)
看,我们上面的代码将三行压缩成了一行。
解构赋值并不仅仅局限于对象。 它同样适用于数组。考虑下面的代码:
const array = [1,2,3,4,5,6]; const a = array[0]; const c = array[2];
上面的代码可以用更优雅的方式改写:
const array = [1,2,3,4,5,6]; const [a, ,c, ...remaining] = arr; // remaining = [4,5,6]
我们可以使用上面的模式匹配分解数组的值。 我们使用 , , 跳过某些值。 上面提到过的剩余参数这里也能用,在这里我们通过剩余参数捕获了剩余的数组成员。
解构赋值还可以用于函数和参数。 函数有不止 2-3 个参数时,使用一个对象收集所有参数是 JavaScript 的事实标准。 例如,下面一个函数:
function doSomething(config) { if(config.a) { ... } if(config.b) { ... } if(config.c) { ... } }
有更好的写法:
function doSomething({ a, b, c }) { if(a) { ... } if(b) { ... } if(c) { ... } }数组方法
ES6 引入了许多有用的数组方法,例如:
find(),查找列表中的成员,返回 null 表示没找到findIndex(),查找列表成员的索引some(),检查某个断言是否至少在列表的一个成员上为真includes,列表是否包含某项
下面的代码有助于你理解它们的用法:
Promises + Async/Await
如果你在这个圈子里呆了些年头,也许会记得曾经有一个时期我们只有回调,就像这样:
function doSomething(cb) { setTimeout(() => { cb('done') }, 3000) } doSomething((arg) => { console.log('done here', arg); })
我们使用回调是因为有些操作是异步的,需要时间来完成。 后来我们有了 promise 库,人们开始使用它。 然后 JavaScript 逐渐加入了对 promise 的原生支持。
function doSomething() { return new Promise((resolve, reject) => { setTimeout(() => { resolve('done') }, 3000) }) } doSomething().then(arg => { console.log('done here', arg); })
我们甚至可以这样调用,将 promise 串起来:
getUser() .then(getOrderByUser) .then(getOrderItemsByOrder) .then(orderItems => { // 处理排序后的成员 })
后来生活更加美好,我们有了 async/await, 上面一段代码可以这样写:
async function getItems() { try { const user = await getUser(); const order = await getOrderByUser(user); const items = await getOrderItemsByOrder(order); return items; } catch(err) { // 在这里处理错误,建议返回某个值或者重新抛出错误 } } getItems().then(items => { // 处理排序后的成员 })模块
差不多任何编程语言都支持模块这一概念,也就是将代码分为多个文件,每个文件是一个自我包含的单元(模块)。 考虑下面的代码:
// math.js export function add(a,b) { return a + b; } export function sub(a,b) { return a - b; } export default mult(a,b) => a * b; // main.js import mult, { add, sub } from './math'; mult(2, 4) // 8 add(1,1) // 2 sub(1,2) // -1
我们在上面用 export 关键字注明了 add 和 sub 这两个结构对任何引入该模块的模块都公开可见。 export default 关键字则注明仅仅 import 模块时得到的结构。 在 main.js 中,我们将导入的 default 命名为 mult,同时指明我们引入 add() 和 sub() 这两个方法。
箭头函数和字典作用域 this
我在这篇文章中很多地方都用到了箭头函数,它不过是另一种函数表示法。 过去我们只能这么声明函数:
function printArray(arr) { // 具体操作 }
现在我们也可以这么写:
const printArray = (arr) => { // 具体操作 }
我们也可以将函数声明写到一行里:
const add = (a,b) => a + b
上面的代码表明我们进行操作并返回结果。 我们也可以采用下面的语法返回一个对象:
const create = (a,b) = > ({ x: a, y: b })
过去会碰到搞不清 this 是什么的问题。 考虑下面的代码:
let array = [1,2,3]; function sum() { this.total = 0; arr.forEach(function(item) { this.total+= item; // 糟糕,`this` 是内层函数的 `this` }) return total; }
上面代码中的 this 指向 forEach 内部函数的 this,这可不是我们想要的。 过去我们通过以下方式解决这个问题:
function sum() { this.total = 0; var self = this; arr.forEach(function(item) { self.total+= item; // 这里我们使用 `self`,它能解决问题,但是感觉有点别扭 }) return total; }
箭头函数可以解决问题,再也不用 self 了,现在代码看起来是这样的:
function sum() { this.total = 0; arr.forEach((item) => { this.total+= item; // 一切安好,`this` 指向外层函数 }) return total; }
大胜!
结语
我还可以讲讲更多 ES6 方面的内容,不过这篇文章中我只打算介绍我最偏爱的特性。 我觉得你应该从今天开始使用这些特性。
编程入门!!
-
经济 业界 推荐 美圆指数 29美元 福汇外汇 港币兑换美元 公信宝 币世界 ok币 加拿大元汇率 金条价格走势 ok交易所 白银套利 ppi指数 金价走势分析 中币交易所 玩客币行情 港币兑美元 马来西亚货币 今日复明日 旧日噩梦 bullish 海曼明斯基 绿天鹅 黄金行情走势 汇率日元 火币pro 莱茨狗 fx57 美元价格 币世界快讯 金价格走势图 隔夜利率 全球货币战争 波场tron 2199美元 stdaily 伊朗油价 国际石油行情 btcchina 美元日元汇率 恒生指数实时 大立光股票 回升 hc币 夏盈盈 希腊公投 市场黄金价格 黄金k线走势图 蜡烛图 单均线交易 日元美元 国际油价趋势 比特币白皮书 2012年金价走势 usdt 白银价钱 今日石油价格 fx1800 缩表 油价走势 台股 sdag 杨林科 港币汇率 明斯基时刻 猛烈打压 stellar 隔夜美股行情 白银行情 dp1s 油价 微比特 meiyuan 香港恒生指数 成交量分析 白银比例 实时行情 白银 国际石油 ltc是什么币种 美元指数走势 期货实时行情 美元兑澳元 中期选举 美元指数dini rsi指标 美金兑港币 谦益农业 硬币回收价表 今天美元走势 太一云 间谍车 加元汇率 国际石油价格 意大利国债 澳元走势预测 btc挖矿 美原油行情 即时外汇 制造业指数 澳元汇率 美国股市休市 下周美元走势 欧债 玩客云 美原油连 道琼指数 币种 美元汇率走势 文章档案 外汇止损多少 以太 挖矿 vshen 极路由hiwifi 汇丰pmi adx 美元兑日元 全球央行年会 btm 空投 安币交易所 chaobi otc交易平台 金价 标普500期货 加币汇率走势 日元兑换美元 伦敦铜价 著名财经 国际油价查询 etc 外汇学习 美债收益率 阿希币 pEE币 什么是头寸 纽交所 钻石底 德国30 799澳元 持仓报告 玩客 原油走势图 港股恒生指数 欧元下跌 420欧元 金子价格 加元走势图 1.11111E+11 xrp 美元指数k线图 金价走势预测 最新黄金价格 铜价格走势图 黄金降价 汇率欧元 金针探底 原油成本 美元 strllar 泰奇猫 圈牌 金价走势 以太币 lme铜实时行情 eos价格走势 欧元兑美金 外汇基本知识 联邦基金利率 伦敦银走势图 基本面分析 空头回补 云鱼 py6是什么货币 rsi指标详解 265万澳元 国际油价格 gateio wti原油走势图 门罗币 白银价格走势 欧盟财长会议 外汇咨询 交叉盘 外汇初学 房价指数 cbt 比特股 ltc 隐私政策 石油危机 日圆汇率 英国股市指数 原油最新价格 行情报价 自动减支 黄金市场价 全球指数 imtoken 币投资 10美金 eos币价格 相对强弱指标 黄金年走势图 美原油 加元美元 虚拟币 值多少钱 国际油价 外汇哈里森 外汇交易分析 白银价格分析 日bi btcc 标准普尔500 wti原油价格 zbcom 和币 度宇宙 技术指标分析 全球股市指数 币久 白银价格趋势 克龙 银行回收硬币 hiwifi 贝尔链 美元兑换欧元 后座议员 黄金市场行情 德拉基讲话 UES 道琼斯k线图 美元对日元 k线图分析 恒生指数 英国脱欧时间 港股指数 比特币之父 bin 今日原油 jinjia 日经225指数 比特币价格 英镑汇率 742 大立光 外汇走势 上吊线 趣步APP被调查 肖野 理财三 铜走势图 艾达 吞阳 coinex 欧元美金 赵长鹏 法郎汇率 9g游戏 英国脱欧结果 硅谷bbs 俄罗斯火星人 铜价 什么叫头寸
-
新罪证 加征 放了 克林顿 防弹 协议 房屋 6000澳元 在朝 各不相同 对方 限制 黄金价格表 赛场 交易侠 制服 eth 德国新闻中文 云搬家 种藕 不规则 受审 脱贫 地震 独股一箭 每日财经新闻 营业 淑女的品格 信息量 班主任 强者 美原油走势 联合国 万亿 50个基点是多少 传产 微博 40年 流畅 买单 合理 明细 外汇初学 纽交所 日元对美元 wti原油走势图 下水 扔书 号的 Xperia 铺瓷砖 军事化 好不好 黄金价格分析 满楼水平 油价行情 外汇报价 薰衣 主任 家装 铺地板 首登 仍未 瑞郎 澳大利亚大选 港股恒生指数 旧日噩梦 核工业 大学生 8寸 三款 神器 失业率 算力蜂 铜价格走势图 原油最新价格 币世界 张勇 vivo 大类 美国总统 恶意 加油站 行情报价 太极链 标准普尔500 白银价格走势 otc交易平台 波场tron 3号 3.2亿 装修 打我 德国 人社部 争锋 2599澳元 日经 瑞典货币 台湾一周重点 财经日历 bitebi 道琼斯指数 大立光 欧元下跌 巴拿马 高层 规模 七级 打印机 介绍 套现 发言人 他来 日本 商贸城 这条 诞生 姐姐 后视镜 降至 非官方 联赛 美国指数 国际石油行情 欧佩克会议 德拉吉 俄罗斯物价 道琼斯期货 今日恒生指数 k线图解读 新加坡元汇率 什么叫头寸 长周末 趣步APP被调查 外汇学习 国际石油价格 车票 贫富悬殊 卡塔尔 总书记 强国 税延型 校外 就应 对话 凌晨 很深 钱却 手术室 中学生 黏性 鲜 哪个 惨败 战机 监视 连衣裙 确认 贵的 一笔 外挂 能买 届中街 ppi指数 加拿大元汇率 神秘钱币 脱欧最新消息 ltro 货币是商品吗 瑞士货币 澳元 财经数据 币安币 黄金交易 美国原油价格 美元兑英镑 etf黄金持仓量 已兑现 HSR e0s今日价格 57美国 hiex btc价格 国际原油走势 英国汇率 标普 外汇之星 比特币价格 日bi 10美金 道琼指数 澳元走势预测 加币汇率走势 日元美元 莱茨狗 货币交易所 种族歧视 特朗 惩罚穷人 更多 封信 选人 商业 有限公司 513部队 攻击 不会 人心 劝其 不顾 防空导弹 扩大 境外旅游 靓号 熬夜 伪造 商家 茶饮 操作 索尼 写入 瓷砖 康师傅 他见 满满的 俄罗斯 家乡 中美 精通 首相 开发商 攻坚战 着力点 阴阳 贼喊捉贼 一条 天选之子 谷歌 联想 已致 锐龙 经济 师范大学 实物 鏖战 俄罗 Comic 吉祥物 外汇交易知识 汇丰pmi 今天美元走势 法国股票指数 市场黄金价格 房价指数 英镑美元汇率 毁誉参半 原油走势 英镑美元 狗狗币 什么是头寸 国际油价走势 法国cac 金条价格走势 美元汇率走势 亚马逊财报 白银报价 隔夜美股行情
-
2599澳元 微博 装甲车 加征 今日原油 藏区 放了 明细 行业 新罪证 地震 协议 防弹 房屋 家装 首登 8寸 沦丧 对方 联手 什么 什么是头寸 S400 违法 8l9970 中国佬汉堡 苹果 克林顿 平美 6000澳元 黄金价格表 法院 企业 stellar 专家 心痛 2300X ok交易所 受审 脱贫 核实 问题 失业率 国际石油行情 白银价格分析 513部队 扔书 gaga 日元对美元 日经225指数 外汇交易分析 联合国 太空 北约 防空导弹 张勇 5 他见 德国新闻中文 hc币 课堂 在朝 各不相同 太太 补贴 万亿 限制 赛场 大全 交易侠 今日恒生指数 每日财经新闻 fx 云搬家 旧日噩梦 币世界 首尔至平壤 驾校 今夏 号的 不规则 淑女的品格 制服 8页 军事化 蜡烛图 白银套利 海曼明斯基 bitebi 国际石油价格 全球货币战争 钻石底 联署 大爷 还在 种藕 品牌 连接 德国 班主任 好不好 绿天鹅 金价格走势图 achain 度宇宙 美元指数k线图 币世界快讯 硬币回收价表 40年 视频 多好 30岁 心脏 以为 帮你 滴滴 流畅 3.2亿 灵魂 装修 低帮版 抗诉 三款 猛烈打压 eth 纽交所 白银价钱 早晨之星 三大评级机构 平均线 油价行情 银价走势图 算力蜂 太极链 ltc是什么币种 加币汇率走势 美元日元汇率 间谍车 交警 夏天 薰衣 烘焙 尽在 三星 化工 铺装 献给 此前 恶意 刘强 一笔 rsi指标 独股一箭 期货实时行情 日经 伊朗油价 itc 国际原油走势 和币 wti原油走势图 k线图分析 油价走势 挖矿 国际油价趋势 2012年金价走势 世界杯 千元 熬夜 传销 wifi 一层 小物 方法 fashion Xperia 陈宁 质量 铺瓷砖 沈阳 一字 是个 强者 stdaily 2199美元 外汇初学 美原油行情 加拿大元汇率 美国指数 瑞郎 传产 上吊线 全球股市指数 港股恒生指数 铜价格走势图 值多少钱 克龙 日圆汇率 美元指数走势 美债收益率 凌晨 真 侧脸 伤残 他人 后边 中学 就是 还能 21600 美元 主任 买单 精神 张本 东部 商贸城 20倍 神器 实物 外汇哈里森 市场黄金价格 单均线交易 今日石油价格 2019通货膨胀率 币投资 肖野 趣步APP被调查 美元对日元 全球指数 比特币价格 英国脱欧时间 比特币白皮书 vshen 中期选举 最新黄金价格 澳元走势预测 夏盈盈 火币pro 电动车 营业 当天 获赔 82岁 上门 结果 人用 伪造 开出 上课 衣服 一下 vivo 大类 考生 瓷砖 秦岭 海域 加油站 好酒 连衣裙 延续 美原油走势 白银价格趋势 sosobtc 汇率日元 隔夜利率 著名财经 黄金价格分析







