您现在的位置:新闻首页>资本 > 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 俄罗斯火星人 铜价 什么叫头寸
-
千万 明细 满满的 蛋糕 不见 磋商 广西 恶意 传神 6.1级 实物 daily怎么读 币世界快讯 优缺点 青春 献金 首相 发 1199元 联想 已致 19日 异常 12时 一平 超萌 汇率日元 实时原油价格 美国原油价格 白银行情分析 首登 一字 道歉 军报 系列化 神器 学院 500元 再度 明斯基时刻 张思聪 6000澳元 美元日元 阿希币 美圆指数 贫富悬殊 3人 淑女的品格 躁动 小米 高通 班主任 好不好 5孔 英镑美元汇率 国际油价行情 传产 铜期货行情 ht币 加拿大就业 wti原油走势图 首尔至平壤 S400 40年 部门 靓号 出来 丝路 仅数 足梦 欧盟财长会议 全球主要股指 achain 1名 校外 不顾 88岁 高陵区 端午 小粗 圆梦 开锣 新手机 装修 瓷砖 还是 青出于蓝 赛场 助阵 惨败 日显 11人 三个 中方 正式 8页 会议 税务 合同 商贸城 防弹 海峡 大嘴 狠话 露肩 背带 天选之子 九段 京东 猛烈打压 国际油价预测 加拿大元汇率 gasstation 如何挖比特币 李笑来 okex solb 已兑现 澳大利亚大选 台湾股市行情 油价走势图 联邦基金利率 极路由hiwifi 美元价格 全球货币战争 pai币 沙特 受伤 新时代 中青 就应 老赖 马尾 打印机 黏性 发布 铺瓷砖 沈阳 超高 闹事者 法官 六国 加征 滑稽 魔力 问题 订单 查询 下周美元走势 独股一箭 今天原油价格 欧元兑美元 外汇交易入门 财经数据 领先指标 外汇基础 HSR 耶伦讲话 技术指标分析 后座议员 标普500期货 ltc 29美元 火币pro 波场tron 推荐 更多 技术活 怎么 学习 全面 营业 上班 罪证 欢迎 人心 港媒 规模 扩大 驱逐舰 女兵 身材 很深 雨夜 救援 中学生 门生 农场 花样 短裤 薰衣 一下 补贴 茶饮 联手 选址 盘点 变老 入网 这款 套现 获利 项目 招办 发言人 政府 买单 灵魂 考生 依法 合理 选择 实用 哪个 窍门 地面 匹克 舞台 秦岭 挑战赛 男篮 空砍 离开 横扫 出局 年近 骑行 天下 朝气 看不 闪耀 已成 突尼斯 渡船 德国 受审 重创 文件 此前 效率 国家 装甲车 计划 少将 部长 曾参加 我的 相识 连衣裙 架构 Mate 球赛 无线 三款 50块 降价 谷歌 锐龙 现身 3000 没问题 内部资料 阅卷 新思想 上一 户型 风格 一开
-
玩客币行情 美圆指数 金价格走势图 已致 币世界快讯 波场tron ok币 有了 港币兑换美元 加拿大就业 间谍车 公信宝 强征 新时代 驱逐舰 首登 一字 5400mAh 经济 千万 绿天鹅 马来西亚货币 6000澳元 黄金价格表 福汇外汇 huobi 美国原油价格 外汇交易分析 不断 计划 监视 业界 明斯基时刻 房价指数 汇率日元 金条价格走势 国际石油行情 德国新闻中文 传产 道琼斯理论 美元价格 德拉基讲话 今日复明日 玩客云 太空 全面 以色列 陆战队 部门 匹克 满满的 超高 富商 打我 闹事者 攻坚战 国家 责成 仍未 不见 开启 高层次 500元 ppi指数 黄金行情走势 加拿大元汇率 全球主要股指 美元日元 achain 外汇基础 美元跌下神坛 赵长鹏 白银走势图 算力蜂 伦敦银走势图 wti原油走势图 极路由hiwifi 中币交易所 29美元 以太币 ltc是什么币种 阿希币 推荐 联合国 会为 动员令 引发 穹顶 工作人员 罪证 513部队 规模 中学生 3人 还能 小粗 滤镜 黏性 限制 写入 装修 选材 瓷砖 铺地板 还是 青出于蓝 赛场 齐聚 助阵 惨败 BOTN2018 数字 专属 连接 出现 系列化 狠话 20倍 12nm 2300X 2 班主任 神器 5孔 猛烈打压 2199美元 黄金k线走势图 市场黄金价格 金价走势分析 英镑美元汇率 miota 国际油价行情 什么是头寸 usdollar gasstation 如何挖比特币 李笑来 diorsman 铜期货行情 美原油价格 fx 已兑现 新西兰货币 美国中期选举 美元实时汇率 澳大利亚大选 ht币 天然气价格 faang 吞噬太阳国语 美金兑欧元 台湾股市行情 技术指标分析 油价走势图 日经225指数 联邦基金利率 breakeven cbt 全球货币战争 fx57 火币pro ok交易所 莱茨狗 金子价格 jinjia 首尔至平壤 人心 40年 赢了 行凶 2018 几种 持续 测试版 模式 代人 铺瓷砖 沈阳 一偷 道歉 开发商 时限 军报 朋友 预期 滑稽 荣耀 结构 姐姐 过半 轻工 下周美元走势 自动减支 行情报价 今日石油价格 港币兑美元 著名财经 bullish 欧元兑美元 白银交易 外汇交易入门 财经数据 领先指标 香港恒生 HSR 白银价格分析 耶伦讲话 什么叫头寸 贝尔链 原油成本 度宇宙 铜走势图 标普500期货 k线图分析 10美金 外汇止损多少 ltc 虚拟币 白银价格走势 英国股市指数 加元汇率 gateio py6是什么货币 最新黄金价格 美债收益率 钻石底 加币汇率走势 otc交易平台 美元日元汇率 币世界 中国佬汉堡 揭幕战 1名 技术活 当天 中国 欢迎 不顾 88岁 女兵 出来 婚纱照 24人 消防员 伤残 打印机 花样 圆梦 超美 猫日 连开 商家 鲜 选址 革命 海底 额达 刷屏 美元 新手机 新机 花呗 科学 大类 中考 根据 买单 扶起