JAVA十大超级好用的功能推荐
Posted fkw777
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA十大超级好用的功能推荐相关的知识,希望对你有一定的参考价值。
简写属性
在 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,列表是否包含某项
下面的代码有助于你理解它们的用法:
const array = [ id: 1, checked: true , id: 2 ];arr.find(item => item.id === 2) // id: 2 arr.findIndex(item => item.id === 2) // 1arr.some(item => item.checked) // trueconst numberArray = [1,2,3,4];numberArray.includes(2) // true
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.jsexport function add(a,b) return a + b; export function sub(a,b) return a - b; export default mult(a,b) => a * b;// main.jsimport mult, add, sub from ‘./math‘;mult(2, 4) // 8add(1,1) // 2sub(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;
以上是关于JAVA十大超级好用的功能推荐的主要内容,如果未能解决你的问题,请参考以下文章