首页 > 语言 > JavaScript > 正文

JS中产生标识符方式的演变

2024-05-06 16:22:18
字体:
来源:转载
供稿:网友

本文记录下JS中产生标识符方式的演变,从ES5到ES6,ES5及其之前是一种方式,只包含两种声明(var/function),ES6则增加了一些产生标识符的关键字,如 let、const、class。

一、ES5时代

var

function

我们知道 JS 不象其它语言 Java、Ruby等,它用来命名变量的只有关键字 var,不论何种类型数据都用 var 声明,当然弱类型并不代表该语言没有类型,它的类型在运行时(根据不同运算符)会隐式转换。而其它语言如Java,光声明数字的关键字就有 int、 float、double、long。

 

 
  1. // JS 
  2. var num1 = 10; // 整数 
  3. var num2 = 10.1; // 浮点数 
  4. var str = 'John'// 字符串 
  5. var boo = false// 布尔 
  6. var obj = {}; // 对象 

 

 
  1. // Java 
  2. int num1 = 10; 
  3. double num2 = 10.2; 
  4. String str = "John"
  5. Boolean boo = false

JS 里标识符除了使用 var 产生,还有一个 function 关键字也可以产生标识符。function 类型声明的标识符的可能是函数、方法或构造器(类)。

 

 
  1. // functions 
  2. function fetchData(url, param) { 
  3. // ...  
  4.  
  5. // methods 
  6. var obj = { 
  7. getUrl: function() { 
  8. }; 
  9.  
  10. // class 
  11. function Person(name, age) {} 
  12. Person.prototype = { 

二、ES6时代

var

function

let

const

class

可以看到,ES6 增加了3个可以产生标识符的关键字 let/const/class。let/const 用来声明变量,class 用来定义类。

 

 
  1. // 定义普通变量 
  2. let name = 'John'
  3. for (let i = 0; i < arr.length; i++) { 
  4. if (boo) { 
  5. let obj = {}; 
  6. ... 
  7.  
  8. // 定义常量 
  9. const PI = 3.1415926; 
  10. const $el = $('.nav'); 
  11.  
  12. // 定义类 
  13. class Point { 
  14. constructor(x, y) { 
  15. this.x = x; 
  16. this.y = y; 
  17. toString() { 
  18. return '('+this.x+', '+this.y+')'

ES6时代,可以想象我们的代码风格里应该是 “少var多let”,let 和 const 都具有块级作用域,且不会发生变量提升。而声明类,也都会使用 class 了,class 关键字分担了 function 的部分任务。

以上所述就是本文的全部内容了,希望大家能够喜欢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选