ECMAScript6新语法(javaScript)

简介: ECMAScript6新语法(javaScript)

一、前提:

ECMAScript6新语法

ECMAScript版本的新语法,不是所有浏览器都兼容,有些浏览器兼容局部


二、ECMAScript的新语法

1、变量定义

5版本:var 变量名:变量使用范围不明确

<script>
  for (var i = 0; i < 10; i++) {
    console.log("in:"+i)
  }
  console.log("out:"+i);
</script>

image.png


6版本: let const:声明变量


let 变量名 用于声明局部变量 作用范围:从定义行开始到所在代码块结束

<script>
  for (let i = 0; i < 10; i++) {
    console.log("in:"+i)
  }
  console.log("out:"+i);
</script>

image.png


const修饰的值不可变(相当于java中的final)


image.png

const修饰的对象地址不可以变,但是属性可以变,可以修改属性


  const  student={id:1,name:"王恒杰"}
  console.log(student);
  //const修饰的对象地址不可以变,但是属性可以变,可以修改属性
  student.id=2;
  console.log(student)
  //增加属性age
  student.age=18;
  console.log(student)

image.png


2、箭头函数

使用场景:匿名函数作为函数的参数

语法:()=>{}等价于function(){}简化了function

5版本:函数 function xx(){}

6版本:箭头函数

 //箭头函数
  function test(func) {
    func(1);
  }
  //5版本:函数 function xx(){}
  test(function (i) {
      alert(i);
  })
  //6版本:箭头函数 ()=>{函数体}
  test((i)=>{
    alert(i);
  })

注意:

(1)函数只有一个参数时,()可以省略不写,参数是多个或者没有参数需要加上小括号

image.png



(2)函数体中只有一行代码,{}也可以省略


image.png


(3)箭头函数没有自己的this,如果在箭头函数中的this,代表当前vue对象,不代表当前函数


image.png


3、模板字符串 ``

在定义变量时 变量中包含html标签可以使用


  //  模板字符串
  let html="<button @click='test1("+'name'+")'>点我</button>"
          +"<button @click='test1("+'name'+")'>点我</button>"
          +"<button @click='test1("+'name'+")'>点我</button>"
          +"<button @click='test1("+'name'+")'>点我</button>"
  console.log(html);
//模板字符串
  let  html1=`<button @click='test1("+name+")'>点我</button>
             <button @click='test1("+name+")'>点我</button>
             <button @click='test1("+name+")'>点我</button>
             <button @click='test1("+name+")'>点我</button>`;
  console.log(html1)

image.png


4、创建对象

//  定义对象
  let id=1;
  let name="王恒杰";
  let age=18;
  //5版本封装对象
  let student={id:id,name:name,age:age};
  console.log(student);
  //6版本封装对象
  var student2={id,name,age};
  console.log(student2)

image.png

相关文章
|
5月前
|
存储 JavaScript 前端开发
Node.js的基本语法
【8月更文挑战第12天】Node.js的基本语法
199 1
|
2月前
|
JavaScript 前端开发 安全
ECMAScript 6(以下简称 ES6)的出现为 JavaScript 带来了许多新的特性和改进,其中 let 和 const 是两个非常重要的关键字。
ES6 引入了 `let` 和 `const` 关键字,为 JavaScript 的变量管理带来了革新。`let` 提供了块级作用域和暂存死区特性,避免变量污染,增强代码可读性和安全性;`const` 用于声明不可重新赋值的常量,但允许对象和数组的内部修改。两者在循环、函数内部及复杂项目中广泛应用,有助于实现不可变数据结构,提升代码质量。
36 5
|
2月前
|
自然语言处理 JavaScript 前端开发
ECMAScript 6 的出现为 JavaScript 带来了许多新的特性和改进
这些只是ES6的一些主要特性,它们极大地增强了JavaScript的功能和表现力,使得JavaScript在大型应用开发、前端框架等领域能够更加高效地编写复杂的应用程序。
|
3月前
|
JavaScript 前端开发
JavaScript 函数语法
JavaScript 函数是使用 `function` 关键词定义的代码块,可在调用时执行特定任务。函数可以无参或带参,参数用于传递值并在函数内部使用。函数调用可在事件触发时进行,如用户点击按钮。JavaScript 对大小写敏感,函数名和关键词必须严格匹配。示例中展示了如何通过不同参数调用函数以生成不同的输出。
|
3月前
|
JavaScript 前端开发 编译器
掌握现代化JavaScript:ECMAScript提案与特性
【10月更文挑战第13天】本文介绍了ECMAScript(ES)的最新提案与特性,包括可选链、空值合并运算符、类字段和顶层Await等。通过跟踪TC39提案、使用Babel或TypeScript、测试兼容性以及逐步迁移,开发者可以高效地采用这些新特性,简化代码、提高开发效率并增强应用功能。文章还提供了实战技巧,帮助开发者在现代Web开发中充分利用这些现代化的特性。
|
4月前
|
Web App开发 JavaScript 前端开发
探索现代JavaScript开发:ECMAScript提案的未来
JavaScript是最受欢迎的编程语言之一,其发展迅速。ECMAScript(JS的标准化版本)的提案和更新为其带来了诸多新特性和改进。本文将介绍值得关注的ECMAScript提案,如可选链、空值合并运算符、逻辑赋值运算符、类字段和顶级Await,并展示如何利用这些新特性提升开发效率和代码质量。通过关注TC39提案流程、使用Babel和TypeScript等工具,开发者可以提前体验并利用这些新特性。随着JavaScript的不断进步,未来将有更多令人期待的功能加入。
|
3月前
|
JavaScript 前端开发 大数据
在JavaScript中,Object.assign()方法或展开语法(...)来合并对象,Object.freeze()方法来冻结对象,防止对象被修改
在JavaScript中,Object.assign()方法或展开语法(...)来合并对象,Object.freeze()方法来冻结对象,防止对象被修改
66 0
|
5月前
|
JavaScript 前端开发
JavaScript基础&实战(1)js的基本语法、标识符、数据类型
这篇文章是JavaScript基础与实战教程的第一部分,涵盖了JavaScript的基本语法、标识符、数据类型以及如何进行强制类型转换,通过代码示例介绍了JS的输出语句、编写位置和数据类型转换方法。
JavaScript基础&实战(1)js的基本语法、标识符、数据类型
|
5月前
|
JavaScript 前端开发 API
JS 与ECMAScript的关系、历史和未来发展
JS 与ECMAScript的关系、历史和未来发展
|
6月前
|
缓存 JavaScript 前端开发
前端框架与库 - Vue.js基础:模板语法、数据绑定
【7月更文挑战第14天】Vue.js 是渐进式框架,以简洁API和高效数据绑定知名。本文聚焦模板语法与数据绑定,解释常见问题和易错点,助力初学者避坑。模板语法中,{{ expression }} 用于渲染值,v-bind/: 用于动态绑定属性。数据绑定涉及文本、属性和事件,注意v-model适用于表单元素,计算属性有缓存。理解正确用法,借助文档和IDE,可提升开发质量和效率。善用Vue.js,打造响应式UI。
190 4