[译]五个ES6功能,让你编写代码更容易

栏目: JavaScript · 发布时间: 5年前

内容简介:众所周知,学习新语法是一件很怪异的事情。我们大多数人都选择我们需要提高工作效率的最低限度,然后偶尔在观看朋友/同事/导师代码时,我们偶尔也发现了一些让我们想知道的事情. 如果没有他们、我们自己该如何生存的新技巧。下面罗列了5个这样的小快捷方式,可以让您编码生活更快一些。一如既往,如果这篇文章对您有用的话,请推荐并分享!

众所周知,学习新语法是一件很怪异的事情。我们大多数人都选择我们需要提高工作效率的最低限度,然后偶尔在观看朋友/同事/导师代码时,我们偶尔也发现了一些让我们想知道的事情. 如果没有他们、我们自己该如何生存的新技巧。

下面罗列了5个这样的小快捷方式,可以让您编码生活更快一些。

一如既往,如果这篇文章对您有用的话,请推荐并分享!

标记的模板文字

模板文字!确实很棒。我们不再会这样做….

const concatenatedString = “I am the “ + number + “ person to recommend this article.”
复制代码

然而,当我们使用下面这种方式做的话:

const concatenatedString = `I am the ${number} person to recommend this article.`
复制代码

是不是很棒!

标记的模板文字允许我们向前迈出一步 - 并使用字符串调用函数。

我们再来看下面这个例子⬇:

const consoleLogAstring = () => {
    console.log(string)
}
consoleLogAstring`I am the string to be logged!`
// I am the string to be logged!
复制代码

换种方式, 看这个⬇:

consoleLogAstring('Here is the string!')
// Here is the string!
复制代码

…与此相同的还有下面这种写法⬇:

consoleLogAString`Here is the string!`
复制代码

标记模板文字还有一个额外的好处;向目标函数传递一个从字符串生成的参数数组。这些参数的排列方式如下:首先,一个字符串数组包围内插值,然后是每个内插值。

我们来看一个例子:

function logOutValues(strings, value1, value2) {
  console.log(strings, value1, value2)
}
logOutValues`Here is one value: ${1} and two: ${2}. Wow!`
// ["Here is one value: ", " and two: ", ". Wow!"] 1 2
复制代码

您可以根据需要为尽可能多的内插值执行此操作,甚至可以像这样操作字符串⬇:

const person = {
    name: "Scott",
    age: 25
}
function experience(strings, name, age) {
  const str0 = strings[0]; // "that "
  const str1 = strings[1]; // " is a "
  let ageStr = 'youngster'; 
  if (age > 99){
    ageStr = 'centenarian';
  }
  return str0 + name + str1 + ageStr;
}
const output = experience`that ${ person.name } is a ${ person.age }`;
console.log(output);
// that Scott is a youngster
复制代码

(感谢 Domenico Matteo对本节的澄清。) 此功能还允许您使用转义序列嵌入DSL(此处更多内容)

这有用吗? 使用字符串调用函数是一种更简洁的方法。它可以更容易地进行插值,并根据插值字符串创建新的字符串。 有关此方面的示例,请查看React的样式化组件库 styled-components

const Title = styled.h1`
  font-size: 1.5em;
  text-align: center;
  color: palevioletred;
`;

<Title>Hello World, this is my first styled component!</Title>
复制代码
[译]五个ES6功能,让你编写代码更容易

隐式的return语句

你写了多少次返回值的函数?

const addOne = (num) => {
  return num + 1
}
console.log(addOne(1))
// 2
复制代码

答:几乎每一次的编写都是这样操作,浪费了那么多时间.

将那些大括号替换为普通的小括号,并利用隐式返回:

const addOne = (num) => (
    num + 1
)
console.log(addOne(1)) 
// 2
复制代码

接下来, 我们进一步进行操作!

const addOne = num => num + 1
console.log(addOne(1)) 
// 2
复制代码

这有用吗?

更少的代码, 更好的可读性。 甚至可以鼓励您编写更小的函数,这样您就可以避免写多行代码了,代码给人的感觉也更干净清晰和整洁了。

[译]五个ES6功能,让你编写代码更容易

参数解构使用默认参数,如果你还没有听说过论证解构,那你就错过了。

const person = { name: 'Scott', attractiveness: 8.5 }
const consoleLogAttributes = ({ name, attractiveness }) => {
  console.log(name, attractiveness)
}
consoleLogAttributes(person)
// 'Scott', 8.5
复制代码

是不是太有用了,但是如果我们在没有参数的情况下调用上面的函数呢?

consoleLogAttributes()
// TypeError: Cannot match against 'undefined' or 'null'.
复制代码

让我们通过设置空对象的默认参数来保存此错误:

const consoleLogAttributes = ({ name, attractiveness } = {}) => {
  console.log(name, attractiveness)
}
复制代码

现在我们再来执行一下上面的程序:

consoleLogAttributes()
// undefined undefined
复制代码

如果不使用任何参数调用 consoleLogAttributes ,就不会再出现错误!我们何不更进一步进行操作呢,尽管…

const consoleLogAttributes = ({ 
  name = 'Default name', 
  attractiveness = '10' 
} = {}) => {
  console.log(name, attractiveness)
}
复制代码

到处都是默认值。这意味着以下两种方法将产生相同的结果:

consoleLogAttributes()
// 'Default name', 10
consoleLogAttributes({})
// 'Default name', 10
复制代码

所以我们总是能创造一些值。

这有用吗?

您的函数将更具弹性,因为它们可以适应未被定义的参数传递。

缺点是上面函数声明中的视觉混乱,但大多数情况下,这是一个小代价用来支持更优雅的回退。

[译]五个ES6功能,让你编写代码更容易

属性值简写(包括函数)

让我们回到上面那个 person 对象。这是一个常见模式: 您有一个变量(例如,name),并且您希望将名为 namekey 设置为 name 的值。

const name = "Scott"
const person = { name: name }
// { name: "Scott" }
复制代码

感谢ES6,您可以这样做:

const name = "Scott"
const person = { name }
// { name: "Scott" } 
复制代码

Aaaaaaaaand 使用多个值执行此操作…

const name = "Scott"
const programmingAbility = "poor"
const person = { name, programmingAbility }
// { name: "Scott", programmingAbility: "poor" }
复制代码

Aaaaaaaaand 甚至可以用函数来做…

const name = “Scott”
const sayName = function() { console.log(this.name) }
const person = { name, sayName }
// { name: “Scott”, sayName: function() { console.log(this.name) }  }
复制代码

并且在对象声明中执行函数声明:

const name = “Scott”
const person = { name, sayName() { console.log(this.name) } }
// { name: “Scott”, sayName: function() { console.log(this.name) }  }
复制代码

以上所述就是小编给大家介绍的《[译]五个ES6功能,让你编写代码更容易》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

软件测试

软件测试

[美]Ron Patton / 张小松、王珏、曹跃 / 机械工业出版社 / 2006-4 / 30.00元

软件测试(原书第2版),ISBN:9787111185260,作者:(美)佩腾(Patton,R.) 著,张小松 等译;张小松译一起来看看 《软件测试》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具