前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >90% 的前端都会使用 ES6 来简化代码,你都用过哪些?

90% 的前端都会使用 ES6 来简化代码,你都用过哪些?

作者头像
coder_koala
发布于 2021-05-28 08:35:29
发布于 2021-05-28 08:35:29
47200
代码可运行
举报
运行总次数:0
代码可运行

前言 (介绍 ECMAScript)

最初 JavaScript 语言有 2 份标准:

ECMA-262:主标准,由 ECMA 国际组织(Ecma International)负责管理(为了让最初的JavaScript 与最初的 JScript 能遵循同一套标准发展而诞生的 ECMAScript ,正好排到了作为 Ecma262 号标准,所以得到 ECMA-262 编号。)

ISO/IEC 16262:第二标准,由国际标准化组织 ISOInternational Standard Organization)和国际电子技术委员会 IECInternational Electrotechnical Commission)负责管理

出于商标版权的原因,规范标准中将这门语言称为 ECMAScript ,所以原则上 JavaScriptECMAScript 指的是同一个东西,但有时也会加以区分:

  • JavaScript:指语言及其实现
  • ECMAScript:指语言标准及语言版本,比如 ES6 表示语言(标准)的第 6 版

ECMAScript 发展历史

  • ECMAScript 1(1997 年 6 月):规范第一版
  • ECMAScript 2(1998 年 6 月):为了同步 ISO 标准,引入了一些小更新
  • ECMAScript 3(1999 年 12 月):增加了正则表达式、字符串处理、控制语句(do-while、switch)、异常处理(try-catch)等众多核心特性
  • ECMAScript 4(2008 年 7 月废除):本来是一次大规模升级(静态类型、模块、命名空间等),但跨度过大,出现了分歧,最终没能推广使用
  • ECMAScript 5(2009 年 12 月):变化不大,加了一些标准库特性和严格模式
  • ECMAScript-5.1(2011 年 6 月):又一次小更新,为了同步 ISO 标准
  • ECMAScript 6(2015 年 6 月):一大波更新,实现了当年 ES4 的许多设想,并正式改为按年份命名规范版本
  • ECMAScript 2016(2016 年 6 月):第一个年度版本,与 ES6 相比,发布周期较短,新特性也相对少些
  • ECMAScript 2017(2017 年 6 月):第二个年度版本...

以后的 ECMAScript 版本(ES2018、ES2019、ES2020 等)都在 6 月正式获准生效

开始 (聚焦 ES6)

这里引用 阮一峰 老师的 ES6标准入门 一书中的总结:ES6 既是一个历史名词,也是一个泛指,含义是 5.1 版本以后的 JavaScript 的下一代标准,涵盖了 ES2015、ES2016、ES2017等,而 ES2015 则是正式名称,特指当年发布的正式版本的语言标准 市面上提到的 ES6 一般是指 ES2015 标准,但有时也是泛指 下一代 JavaScript

本文主要讲解以下内容:

  • 块级作用域(Block scoping,ES2015)
  • 解构(Destructuring,ES2015)
  • 箭头函数(Arrow Functions,ES2015)
  • 模板字符串(template string,ES2015)
  • 剩余参数 / 展开语法(Rest and spread parameters,ES2015)
  • 对象字面量简写语法(Object shorthand,ES2015)
  • 数组实例的 includes() (ES2016)
  • Async/await 异步语法 (ES2017)

块级作用域

为什么需要块级作用域?

ES5 只有全局作用域和函数作用域,没有块级作用域,这导致很多场景不合理。

  • 第一种场景,内层变量可能会覆盖外层变量。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var tmp = new Date()
function fn() {
  console.log(tmp)
  if (false) {
    var tmp = 'hello world'
  }
}
fn() // undefined
复制代码

以上代码的原意是, if 代码块的外部使用外层的 tmp 变量,内部使用内层的 tmp 变量。但是,函数 fn 执行后,输出结果为 undefined ,原因在于变量提升导致内层的 tmp 变量覆盖了外层的 tmp 变量。

  • 第二种场景,用来计数的循环变量泄露为全局变量。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var s = 'hello'
for (var i = O; i < s.length; i++) {
  console.log(s[i])
}
console.log(i) // 5
复制代码

上面的代码中,变量 i 只用来控制循环,但是循环结束后,它并没有消失,而是泄露成了全局变量。

let 实际上为 JavaScript 新增了块级作用域。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
function fl() {
  let n = 5
  if (true) {
    let n = 10
  }
  console.log(n) // 5
}
复制代码

上面的函数有两个代码块,都声明了变量 n,运行后输出 5 。这表示外层代码块不受内层代码块的影响。如果使用 var 定义变量 ,最后输出的值就是 10

那么我们能利用块级作用域做什么呢?

我们先来做道面试题

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
for (var i = 0; i < 5; i++) {
  setTimeout(() => {
    console.log(i)
  }, 1000)
}
// 5 5 5 5 5
复制代码

改成 ES6 中的 let

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
for (let i = 0; i < 5; i++) {
  setTimeout(() => {
    console.log(i)
  }, 1000)
}
// 0 1 2 3 4
复制代码

看到这,相信聪明的你已经理解块级作用域的好处了 O(∩_∩)O

那么 ES5 能不能实现 块级作用域 的效果呢? 可以的,我们可以利用闭包

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
for (var i = 0; i < 5; i++) {
  ;(function (index) {
    setTimeout(() => {
      console.log(index)
    }, 1000)
  })(i)
}
// 0 1 2 3 4
复制代码

解构

解构 :是将一个数据结构分解为更小的部分的过程。ES6 中,从数组和对象中提取值,对变量进行赋值。

那么解构有什么用处呢?

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
可以大大的简化变量声明操作。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// ES5
var foo = 1
var bar = 2
var baz = 3

// ES6
let [foo, bar, baz] = [1, 2, 3]
复制代码
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
变量交换:看起来如同镜像。赋值语句的左侧的解构模式,右侧是临时创建的数组字面量。x 被赋值为数组中的 y,y 被赋值为数组中的 x。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
let x = 1
let y = 2
;[x, y] = [y, x]
// x = 2, y = 1
复制代码
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
对象解构
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var obj = { x: 1, y: 2, c: 1 }
let { x, y } = obj
// x = 1
// y = 2
复制代码
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
字符串解构
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const [a, b, c, d, e] = 'hello'
// a => h
// b => e
// c => l
// d => l
// e => o
复制代码
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
函数参数解构
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const xueyue = {
  name: '雪月',
  age: 18,
}

function getAge({ name, age }) {
  return `${name}今年${age}`
}

getAge(xueyue) // 雪月今年18岁
复制代码

箭头函数

ES6 允许使用箭头 => 定义函数

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var f = v => v

// 等同于 ES5 的
var f = function (v) {
  return v
}
复制代码

如果箭头函数不需要参数或需要多个参数,就使用圆括号代表参数部分。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var f = () => 5
// 等同于 ES5 的
var f = function () {
  return 5
}

var sum = (numl, num2) => numl + num2
// 等同于 ES5 的
var sum = function (numl, num2) {
  return numl + num2
}
复制代码

箭头函数可以与解构结合使用。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const full = ({ first , last }) => first + ' ' + last;
// 等同于 ES5 的
function full(person) {
  return person.first + ' ' + person.last;
}
复制代码

箭头函数使得表达更加简洁

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const isEven = n => n % 2 === 0
const square = n => n * n

var result = values.sort((a, b) => a - b)
// 等同于 ES5 的
var result = values.sort(function (a, b) {
  return a - b
})
复制代码

上面代码只用了两行,就定义了两个简单的工具函数。如果不用箭头函数,可能就要占用多行,而且还不如现在这样写醒目。

箭头函数使用注意点

  1. 函数体内的 this 对象,就是定义时所在的对象,而不是使用时所在的对象。
  2. 不可以当作构造函数,也就是说,不可以使用 new 命令,否则会抛出一个错误。
  3. 不可以使用 arguments 对象,该对象在函数体内不存在。如果要用,可以用 rest 参数代替。
  4. 不可以使用 yield 命令,因此箭头函数不能用作 Generator 函数。

上面四点中,第一点尤其值得注意。this 对象的指向是可变的,但是在箭头函数中,它是固定的。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// ES6
function foo() {
  setTimeout(() => {
    console.log('id:', this.id)
  }, 100)
}

// 转换成ES5
function foo() {
  var _this = this

  setTimeout(function () {
    console.log('id:', _this.id)
  }, 100)
}
复制代码

上面代码中,转换后的 ES5 版本清楚地说明了,箭头函数里面根本没有自己的 this,而是引用外层的 this

模板字符串

模板字符串( template string )是增强版的字符串 ,用反引号 (``) 标识 。它可以当作普通字符串使用,也可以用来定义多行字符串,或者在字符串中嵌入变量。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const { log } = console
const name = '雪月'
const age = 18

// 普通字符串拼接
const result = name + '今年' + age + '岁'
// 使用模板字符串
const result2 = `${name}今年${age}`
log(result) // 雪月今年18岁
log(result2) // 雪月今年18岁

// ${} 大括号可以放入任意的 JavaScript 表达式,可以进行运算
const result3 = `${name}今年${age * 2}`
log(result3) // 雪月今年36岁
复制代码

剩余参数 / 展开语法

ES6 引入了 rest 参数(形式为...变量名),用于获取函数的多余参数,这样就不需要使用 arguments 对象了。rest 参数搭配的变量是一个数组,该变量将多余的参数放入其中。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
function sortNumbers() {
  return Array.prototype.slice.call(arguments).sort()
}
// 使用 rest
const sortNumbers = (...numbers) => numbers.sort()
复制代码

比较上面的两种写法可以发现, rest 参数的写法更自然也更简洁。

扩展运算符( spread )是三个点(...) 如同 rest 参数的逆运算 将一个数组转为用逗号分隔的参数序列

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
console.log(...[1, 2, 3])
// 1 2 3

console.log(1, ...[2, 3, 4], 5)
// 1 2 3 4 5
复制代码

下面是扩展运算符取代 apply 方法的一个实际例子 应用 Math.max 方法简化求出数组中的最大元素。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// ESS 的写法
Math.max.apply(null, [14, 3, 77])
// ES6 的写法
Math.max(...[14, 3, 77])
// 等同于
Math.max(14, 3, 77)
复制代码

扩展运算符提供了数组合并的新写法。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
//  ESS
;[1, 2].concat(more)
// ES6
;[1, 2, ...more]
复制代码

对象的扩展运算符(...)用于取出参数对象的所有可遍历属性,拷贝到当前对象之中。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
let z = { a: 3, b: 'bb' }
let n = { ...z }
n // { a: 3, b: 'bb' }
n === z // false
复制代码

特别注意: ...扩展对象,只能做到当对象属性是 基本数据类型 才是 深拷贝,如果是 引用数据类型,那就是浅拷贝

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
let z = { a: 3, b: 'bb', c: { name: 'ccc' } }
let n = { ...z }

n // { a: 3, b: 'bb', c: { name: 'ccc' } }
n === z // false
n.c === z.c // true
// n.c 跟 z.c 是同一个引用地址
复制代码

对象字面量简写语法

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const name = '雪月'

// ES5写法
const obj = {
  name: name,
  f: function () {
    console.log(this.name)
  },
}

// ES6简写
const obj2 = {
  name,
  f() {
    console.log(this.name)
  },
}

obj.f() // 雪月
obj2.f() // 雪月
复制代码

使用 vue 的同学是不是感到很熟悉

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
new Vue({
  el: '#app',
  data() {
    return {
      list: [],
    }
  },
})
复制代码

数组实例的 includes()

Array.prototype.includes 方法返回一个布尔值,表示某个数组是否包含给定的值,与字符串的 includes 方法类似。ES2016 引入了该方法。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
;[1, 2, 3].includes(2) // true
;[1, 2, 3].includes(4) // false
;[1, 2, NaN].includes(NaN) // true
复制代码

没有该方法之前,我们通常使用数组的 indexOf 方法,检查是否包含某个值。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// ES5
if (arr.indexOf(el) !== -1) {
  // ...
}

// ES6
if (arr.includes(el)) {
  // ...
}

// 那么 indexOf 能不能做到类似于 includes 的写法呢? 我们可以利用 ~ 位运算符
if (~arr.indexOf(el)) {
  // ...
}
复制代码

indexOf 方法有两个缺点,一是不够语义化,它的含义是找到参数值的第一个出现位置,所以要去比较是否不等于-1,表达起来不够直观。二是,它内部使用严格相等运算符(===)进行判断,这会导致对 NaN 的误判。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
;[NaN].indexOf(NaN)
// -1
复制代码

includes 使用的是不一样的判断算法,就没有这个问题

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
;[NaN].includes(NaN)
// true
复制代码

Async/await 异步语法

ES2017 标准引入了 async 函数,使得异步操作变得更加方便。

async 函数是什么?一句话,它就是 Generator 函数的语法糖。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
async function getTitle(url) {
  let response = await fetch(url)
  let html = await response.text()
  return html.match(/<title>([\s\S]+)<\/title>/i)[1]
}

getTitle('https://tc39.github.io/ecma262/').then((res) => console.log(res))
复制代码

上面代码中,函数 getTitle 内部有三个操作:抓取网页取出文本匹配页面标题。只有这三个操作全部完成,才会执行 then 方法里面的 console.log

结束(意犹未尽)

文章介绍了 ES6 常用的一些语法以及使用场景; 但是 ES6 内容远不止于此,感兴趣的同学可以去 阮一峰老师的 ES6 入门教程 一书中查看详细内容。如果您认可这本书,也可以去正版渠道购买书籍。这样可以使出版社不因出版开源书籍而亏钱,进而鼓励更多的作者开源自己的书籍。

后记(列举API)

还有很多 ES6 实用的 API 我就简单提及一下,朋友们看看平时是否有用到

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
;[1, 4, -5, 10].find(n => n < 0)
// -5

;[1, 5, 10, 15].findIndex((value, index, arr) => value > 9) 
// 2

;[1, 2, [3, [4, 5]]].flat()
// [1, 2, 3, [4, 5]]

;[1, 2, [3, [4, 5]]].flat(2)
// [1, 2, 3, 4, 5]

;[3, 8, 54, 8, 3, NaN, NaN, 'NaN', 'NaN'].filter((number, index, arr) => arr.indexOf(number) === index)
// [3, 8, 54, "NaN"] 利用filter过滤去重,注意会漏掉NaN

;[1, 2, 3, 4].map((item) => item * 2)
// [2, 4, 6, 8] 利用map返回一个新数组,不改变原数组

// 使用 reduce 求和; reduce功能极其强大 ! yyds
;[0, 1, 2, 3, 4].reduce(function(accumulator, currentValue, currentIndex, array){
  return accumulator + currentValue;
}); 
// 10

// ES2017 引入了跟 Object.keys 配套的 Object.values 和 Object.entries,作为遍历一个对象的补充手段,
// 供 for...of 循环使用。
let { keys, values, entries } = Object;
let obj = { a: 1, b: 2, c: 3 };

for (let key of keys(obj)) {
  console.log(key); // 'a', 'b', 'c'
}

for (let value of values(obj)) {
  console.log(value); // 1, 2, 3
}

for (let [key, value] of entries(obj)) {
  console.log([key, value]); // ['a', 1], ['b', 2], ['c', 3]
}
复制代码

关于本文

作者:雪月

https://juejin.cn/post/6960868793140641799

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-05-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序员成长指北 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
首个转型AI公司的新势力,在全球AI顶会展示下一代自动驾驶模型
上周三,全球首款 L3 级算力「AI 汽车」小鹏 G7 正式亮相,其首发搭载的三颗自研图灵 AI 芯片,超过 2200TOPS 有效算力,本地部署的 VLA+VLM 模型等特性引发了关注。
机器之心
2025/06/19
890
首个转型AI公司的新势力,在全球AI顶会展示下一代自动驾驶模型
奥特曼惊世预言:下一代人类注定被AI碾压!人类工资暴跌,难以生存
有人说,CS专业算是「搬起石头砸自己的脚」,不过「覆巢之下,安有完卵」?AGI也「不会放过」其他专业的毕业生。
新智元
2025/02/04
960
奥特曼惊世预言:下一代人类注定被AI碾压!人类工资暴跌,难以生存
UC伯克利教授惊人预测:2030年GPT可执行人类180万年工作,一天学2500年知识
UC伯克利的一位机器学习教授Jacob Steinhardt发表长文,对2030年的GPT(以下简称为GPT 2030)作了预测。
新智元
2023/09/09
2560
UC伯克利教授惊人预测:2030年GPT可执行人类180万年工作,一天学2500年知识
奥特曼老黄齐预测:AGI五年内降临,代替95%工作!但马斯克断言AGI将被电力卡脖子
Claude 3、Sora、Gemini 1.5 Pro的纷纷出现,以及或许今年内就会被放出的GPT-5,让所有人都不约而同地隐隐感觉:我们似乎离AGI似乎越来越近了。
新智元
2024/03/13
2010
奥特曼老黄齐预测:AGI五年内降临,代替95%工作!但马斯克断言AGI将被电力卡脖子
OpenAI前员工预测:2027年AGI降临!GPT智商飙升,4年从幼儿园蹿到高中生
几天前,Anthropic一名25岁的高管在博客上发文,表示自己已经准备好了3年后退休,让AI取代自己的工作。
新智元
2024/06/17
2720
OpenAI前员工预测:2027年AGI降临!GPT智商飙升,4年从幼儿园蹿到高中生
谷歌工程师硬核长篇预测,证实黄仁勋观点:AGI或在2029年出现,AI五年内通过人类测试
在斯坦福大学举行的一个经济论坛上,黄仁勋回答了这个问题:人类何时能创造像人类一样思考的计算机?
新智元
2024/03/13
1820
谷歌工程师硬核长篇预测,证实黄仁勋观点:AGI或在2029年出现,AI五年内通过人类测试
麦肯锡预测2030年:1亿中国人面临职业转换,全球8亿人被机器人取代
作者:麦肯锡 纵观人类技术的发展历程,往往遵循一个固定的规律,即先是概念萌芽,然后经历市场炒作,资本蜂拥,结果潮水退去,泡沫破灭。而繁华落尽后,才会经历技术成熟的阶段,直到最后的落地应用,人工智能的发展也是顺应这个规律。如今AI技术正逐渐走出实验室,走进我们生活。未来AI会给我们带来哪些改变?谁都没有答案,正如《南风窗》写的那样:“今天怎么想象未来,都是幼稚的”。但我们应该相信一个尊重科技的社会一定能够向好而生,愿在未来,机器能成为人类的合伙人,而不是对手,更不是替代者。 近日,麦肯锡全球研究院(McKi
钱塘数据
2018/03/06
2.2K0
麦肯锡预测2030年:1亿中国人面临职业转换,全球8亿人被机器人取代
Bengio预言o1无法抵达AGI!Nature权威解读AI智能惊人进化,终极边界就在眼前
Nature最新一篇长文,从人类一直在思考的AGI问题入手,探究了o1掀起的新范式。
新智元
2025/02/15
750
Bengio预言o1无法抵达AGI!Nature权威解读AI智能惊人进化,终极边界就在眼前
AI大神狂喷Sora,力推世界模型,到底谁才是实现AGI的正解?
OpenAI基于Transformer架构开发出的ChatGPT以及近期的Sora大火,但是不少AI界权威人物却狂喷这一技术路线,力推世界模型。那么,Transformer与世界模型到底谁才代表未来,谁更有希望实现我们的终极梦想——AGI?
数据猿
2024/03/04
2210
AI大神狂喷Sora,力推世界模型,到底谁才是实现AGI的正解?
2028年人类将迎来AGI:DeepMind联合创始人长文预测未来AI发展
10月26日,在X上有三万订阅的Dwarkesh Podcast(矮人播客)主持人Dwarkesh Patel采访了谷歌DeepMind的创始人兼首席AGI科学家Shane Legg。
新智元
2023/11/13
3340
2028年人类将迎来AGI:DeepMind联合创始人长文预测未来AI发展
前OpenAI首席科学家Ilya: 只要能够预测下一个token,人类就能达到AGI
近日,Nature将前OpenAI首席科学家Ilya Sutskever评为「2023年10大科学人物」。
新智元
2023/12/20
2520
前OpenAI首席科学家Ilya: 只要能够预测下一个token,人类就能达到AGI
AGI前夜的思考:2025年将出现真正的AI智能体,年轻人需要快速适应
2025 新年将至。对于新的一年和未来几年,你对 AI 领域有什么期待和设想呢?你是否认为 AGI 将要实现了而人类社会的一切都将因之而改变。
机器之心
2025/02/15
1420
AGI前夜的思考:2025年将出现真正的AI智能体,年轻人需要快速适应
与OpenAI CEO萨姆·阿尔特曼对话:AGI将在10年后到来
现在让我介绍一下萨姆·阿尔特曼(Sam Altman)。萨姆是大家熟悉的连续创业者,他曾担任YC的总裁,现在是OpenAI的CEO,他还投资了包括Airbnb、Stripe等公司,甚至还参与了Heon这样的能源融合公司。他帮助建立了World Coin,一种新的加密协议,可以说他涉足过很多领域的投资。他可谓涉及众多领域,且都做得很好。欢迎萨姆!感谢他加入这一轮讨论。
AIGC部落
2024/09/30
1920
与OpenAI CEO萨姆·阿尔特曼对话:AGI将在10年后到来
末日时间表来了!前OpenAI研究员76页硬核推演:2027年ASI接管世界,人类成NPC
今天,前OpenAI研究员和同事们发出一篇「AI 2027」报告,长达76页,做出了种种硬核预测。
新智元
2025/04/05
1110
末日时间表来了!前OpenAI研究员76页硬核推演:2027年ASI接管世界,人类成NPC
思考总结10年,图灵奖得主Yann LeCun指明下一代AI方向:自主机器智能
选自arXiv 作者:Yann LeCun 机器之心编译 编辑:小舟、陈萍 在这篇长达 62 页的论文中,LeCun 表示,这篇论文提炼了他对过去 5 年 - 10 年关于 AI 发展大方向的思考,这基本上是他计划在接下来的 10 年中开展的工作,也是他希望激励其他人从事的工作。 随着机器学习的不断发展,领域内的研究者开始思考一个问题:我们离通用人工智能(AGI)还有多远? 要实现 AGI,最关键的一点是让机器了解世界是如何运转的,掌握广泛的现实知识。 这也是图灵奖得主 LeCun 近期在探索的问题。他曾
机器之心
2022/06/29
6350
思考总结10年,图灵奖得主Yann LeCun指明下一代AI方向:自主机器智能
马斯克最新预测:AI或在2030年超越人类智力,未来还可能“终结”人类
② 马斯克谈了制约AI发展的因素,去年是AI芯片供应紧张,今年降压变压器将成为瓶颈。
小腾资讯君
2024/04/07
2290
十年内出现AGI?下一代Gemini能感知环境?DeepMind CEO哈萨比斯畅谈AI
「如果我们在未来十年内拥有类似 AGI 的系统,我不会感到惊讶。」Google DeepMind 联合创始人和 CEO Demis Hassabis 近日在人工智能播客节目 Dwarkesh Podcast 上如是说。
机器之心
2024/03/07
1430
十年内出现AGI?下一代Gemini能感知环境?DeepMind CEO哈萨比斯畅谈AI
Yann LeCun最新万字演讲:致力于下一代AI系统,我们基本上不做LLM了
Yann LeCun 最新哈德逊论坛演讲:仅通过文本训练,LLM 永远不会达到接近人类水平的智能。所以现在 Meta 已经转向了更长期的下一代 AI 系统研究,基本不再专注于 LLM 了。
Datawhale
2024/10/21
2410
Yann LeCun最新万字演讲:致力于下一代AI系统,我们基本上不做LLM了
麦肯锡发布生成式AI报告,预测2030可达人类水平
2016年DeepMind搞出AlphaGo,击败世界冠军李世石的那会儿,AI曾经铺天盖地的进入到我们的视野中一次,但因为仅仅局限在围棋游戏,后来风头一过,就慢慢淡出了。
新智元
2023/10/20
3430
麦肯锡发布生成式AI报告,预测2030可达人类水平
AGI时代,财富大洗牌!Hinton分解未来财富流向,普通人何去何从
在《经济蓝图》中,OpenAI描绘了AI带给人类的未来:不久的将来,普通人的生活将比现在最「壕」的富豪,生活得更好。
新智元
2025/02/04
1280
AGI时代,财富大洗牌!Hinton分解未来财富流向,普通人何去何从
推荐阅读
首个转型AI公司的新势力,在全球AI顶会展示下一代自动驾驶模型
890
奥特曼惊世预言:下一代人类注定被AI碾压!人类工资暴跌,难以生存
960
UC伯克利教授惊人预测:2030年GPT可执行人类180万年工作,一天学2500年知识
2560
奥特曼老黄齐预测:AGI五年内降临,代替95%工作!但马斯克断言AGI将被电力卡脖子
2010
OpenAI前员工预测:2027年AGI降临!GPT智商飙升,4年从幼儿园蹿到高中生
2720
谷歌工程师硬核长篇预测,证实黄仁勋观点:AGI或在2029年出现,AI五年内通过人类测试
1820
麦肯锡预测2030年:1亿中国人面临职业转换,全球8亿人被机器人取代
2.2K0
Bengio预言o1无法抵达AGI!Nature权威解读AI智能惊人进化,终极边界就在眼前
750
AI大神狂喷Sora,力推世界模型,到底谁才是实现AGI的正解?
2210
2028年人类将迎来AGI:DeepMind联合创始人长文预测未来AI发展
3340
前OpenAI首席科学家Ilya: 只要能够预测下一个token,人类就能达到AGI
2520
AGI前夜的思考:2025年将出现真正的AI智能体,年轻人需要快速适应
1420
与OpenAI CEO萨姆·阿尔特曼对话:AGI将在10年后到来
1920
末日时间表来了!前OpenAI研究员76页硬核推演:2027年ASI接管世界,人类成NPC
1110
思考总结10年,图灵奖得主Yann LeCun指明下一代AI方向:自主机器智能
6350
马斯克最新预测:AI或在2030年超越人类智力,未来还可能“终结”人类
2290
十年内出现AGI?下一代Gemini能感知环境?DeepMind CEO哈萨比斯畅谈AI
1430
Yann LeCun最新万字演讲:致力于下一代AI系统,我们基本上不做LLM了
2410
麦肯锡发布生成式AI报告,预测2030可达人类水平
3430
AGI时代,财富大洗牌!Hinton分解未来财富流向,普通人何去何从
1280
相关推荐
首个转型AI公司的新势力,在全球AI顶会展示下一代自动驾驶模型
更多 >
LV.1
这个人很懒,什么都没有留下~
目录
  • 前言 (介绍 ECMAScript)
  • ECMAScript 发展历史
  • 开始 (聚焦 ES6)
    • 块级作用域
    • 解构
    • 箭头函数
    • 模板字符串
    • 剩余参数 / 展开语法
    • 对象字面量简写语法
    • 数组实例的 includes()
    • Async/await 异步语法
  • 结束(意犹未尽)
  • 后记(列举API)
  • 作者:雪月
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档