您现在的位置:新闻首页>资本 > 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 俄罗斯火星人 铜价 什么叫头寸
-
扶起 fx1800 关于黄金交易 将被 芯片超人 部门 多张 港元兑换 黄金美元 暴涨 政治活 身陷 fashion 复合型 篡改 军报 OPPO 平板 贸易帐赤字 日元比例 钯金行情 间谍车 就应 悲愤 格力 数据 区别 男篮 仅数 入股 天选之子 一平 白银的价格 挖矿卡 还能 最新 三角 卷起来 两车 着力点 预约 九段 去年 大学英语 足梦 adx 明斯基时刻 法国股票指数 美金兑港币 youjia eunice 澳大利亚股市 数字币 eos什么意思 满楼水平 zeniex coinsky bigone 康尼格拉 澳元走势预测 幻灭 律师 5年 集团 侵华 火锅 揭秘 赛场 Marc 淑女的品格 柏林 新成果 汽车业 朱日 滑稽 隐藏 高考成绩 多措 大立光股票 baiyin 行情报价 什么是头寸 国际石油行情 白银交易 美元兑欧元 石油价格查询 区间交易法 央行 k线图分析 vshen meiyuan usdt 油价 关税 介入 足球 终点 泄露 营业 耳机 513部队 打预防针 伤残 伪造 100平米 长相 效率 一条 架构 电池 2300X 网售 开关 以太坊 白银价钱 海曼明斯基 港币兑换美元 欧元兑换美金 英镑走势 外汇交易入门 原油实时价格 一剂强心剂 通货膨胀预期 外汇策略 sho 止损指令 德国30 日本股市指数 金价走势预测 实时黄金价格 即时外汇 cbt chaobi 日元美元 2012年金价走势 玩客云 封信 更是 起火 核工业 陆战队 永久 拍卖 手机 开出 大展 美元 新手机 企业 流畅 Xperia 模式 阶段 套现 主播 创造 故事 突尼斯 激怒 脱贫 侦察 来了 安全性 已致 12时 经济 千万 明细 体育用品 奔奔 业界 汇丰pmi 房价指数 马来西亚货币 eth 隔夜美股行情 希腊公投 2599澳元 美元港币 国际原油k线图 lme铜实时行情 港股指数 交叉盘 圈牌 恒生指数实时 油价走势 杨林科 挖矿 btm 澳元汇率 ok交易所 微比特 公布 有限公司 协议 新罪证 S400 港媒 一个 写下 教师忌语 师生 欧冠 西安 gaga 什么 腾讯 介绍 搭载 能上 注意事项 对比 罚球 兴博杯 而跑 满满的 11人 相撞 攻坚战 曾参加 疏影 马思 开启 iPhone 外挂 广西 实物 运动 闭幕 六一 rsi指标 国际油价预测 毁誉参半 意大利国债 比原链 期货实时行情 欧元美元 外汇对冲交易 黄金实时 白银实时行情 原油石油价格 黄金etf是什么 赵长鹏 技术指标分析 黄金市场价 度宇宙 网络名人堂 265万澳元 eos币价格 理财三 wti原油走势图 UES 持仓报告 799澳元 缩表 值多少钱 比特币白皮书 美元兑日元 英国股市指数 py6是什么货币 btc挖矿 泰奇猫 币久 ltc是什么币种 加币汇率走势 国际油价趋势 太一云 stellar
-
ok交易所 朋友 门罗币 恒生指数实时 美圆指数 隔夜利率 港币兑换美元 市场黄金价格 dp1s 513部队 日本 2199美元 2012年金价走势 港币汇率 福汇外汇 fx otc交易平台 火币pro 仅数 回升 绿天鹅 国际石油行情 持仓报告 圈牌 英国股市指数 金子价格 人心 明细 金条价格走势 道琼指数 玩客币行情 币世界快讯 推荐 金价走势分析 汇率日元 美元指数k线图 cbt 钻石底 hc币 谦益农业 老赖 效率 脱贫 千万 adx 今天美元走势 美原油行情 今日石油价格 意大利国债 极路由hiwifi 美元日元汇率 玩客云 房价指数 btc挖矿 油价走势 罪证 永久 拍卖 fashion 腾讯 电池 网售 外汇哈里森 stdaily 白银价钱 关于黄金交易 即时外汇 中币交易所 美国 有限公司 微信 总决赛 突尼斯 下周美元走势 明斯基时刻 白银套利 加拿大元汇率 印度卢比 19929日元 德国30 ltc 国际石油价格 杨林科 香港恒生指数 美国股市休市 成鬼 驾校 能上 背带 运动 猛烈打压 白银 rsi指标 金价格走势图 bullish 国际原油k线图 基本面分析 pEE币 美元指数走势 莱茨狗 微比特 受伤 欢迎 身陷 人用 尽在 怎样 他来 淑女的品格 23日 行情报价 白银价格趋势 eos什么意思 今日恒生指数 coinex 原油成本 比特币白皮书 安币交易所 公信宝 揭幕战 40年 赛场 首登 发表声明 已致 拜登大胜 缩表 原油最新价格 黄金年走势图 外汇学习 澳元走势预测 btm 将被 完全 驱逐舰 搭载 地方 着力点 核实 体育用品 国际石油 fx380 zeniex 铜价 全球股市指数 最新黄金价格 全球货币战争 usdt 澳元汇率 间谍车 1名 当天 救援 开出 火锅 匹克 来了 谷歌 黄金行情走势 苏格兰公投 今日日历 459美元 外汇走势 道琼斯k线图 俄罗斯火星人 美原油连 值多少钱 etc 台股 xrp 阿希币 贫富悬殊 强国 防空导弹 为国 3万 赢了 砸伤 西安 老太 鲜 美元 哪些 对比 班主任 汇丰pmi 国际油价查询 期货实时行情 otc交易 k线图技术分析 区间交易法 股市行情图 18美元 白银价格分析 康尼格拉 后座议员 wti原油走势图 vshen 夏盈盈 金价 油价 你吗 交警 下个 滑稽 6.1级 外挂 美金兑港币 白银比例 2599澳元 火币比特币 度宇宙 btcc 理财三 港股恒生指数 联邦基金利率 gateio 泰奇猫 空投 stellar 军事 商业 用户 科学 打我 青年 国企 涉税 又放 29日 什么是头寸 意大利脱欧 黄金价钱 港元兑换 一剂强心剂 amadori 欧元下跌 文章档案 银行回收硬币 美原油 成交量分析 美元兑澳元 sdag 强征 律师 靓号 欧冠 3人 化工 秦岭 高关税 疏影 大立光股票 实时行情 eth 美元汇率走势 白银行情 澳洲大选 265万澳元 k线图分析 美债收益率 日元美元 太一云 泄露 男篮 大学英语 查询 日元兑美元







