JS中产生标识符方式的演变
作者:bea
一、ES5时代 var function 我们知道 JS 不象其它语言 Java、Ruby等,它用来命名变量的只有关键字 var,不论何种类型数据都用 var 声明,当然弱类型并不代表该语言没有类型,它的类型在运行时(根据不同运算符)会隐式转换。而其它语言如Java,光声明数字的关键字就有 int、 float、double、long。 // JSvar num1 = 10; // 整数var num2 = 10.1; // 浮点数var str = 'John
一、ES5时代
var function 我们知道 JS 不象其它语言 Java、Ruby等,它用来命名变量的只有关键字 var,不论何种类型数据都用 var 声明,当然弱类型并不代表该语言没有类型,它的类型在运行时(根据不同运算符)会隐式转换。而其它语言如Java,光声明数字的关键字就有 int、 float、double、long。
// JS
var num1 = 10; // 整数
var num2 = 10.1; // 浮点数
var str = 'John'; // 字符串
var boo = false; // 布尔
var obj = {}; // 对象
// Java
int num1 = 10;
double num2 = 10.2;
String str = "John";
Boolean boo = false;
JS 里标识符除了使用 var 产生,还有一个 function 关键字也可以产生标识符。function 类型声明的标识符的可能是函数、方法或构造器(类)。
// functions
function fetchData(url, param) {
// ...
}
// methods
var obj = {
getUrl: function() {
}
};
// class
function Person(name, age) {}
Person.prototype = {
}
二、ES6时代
var function let const class 可以看到,ES6 增加了3个可以产生标识符的关键字 let/const/class。let/const 用来声明变量,class 用来定义类。
// 定义普通变量
let name = 'John';
for (let i = 0; i < arr.length; i++) {
}
if (boo) {
let obj = {};
...
}
// 定义常量
const PI = 3.1415926;
const $el = $('.nav');
// 定义类
class Point {
constructor(x, y) {
this.x = x;
this.y = y;
}
toString() {
return '('+this.x+', '+this.y+')';
}
}
ES6时代,可以想象我们的代码风格里应该是 “少var多let”,let 和 const 都具有块级作用域,且不会发生变量提升。而声明类,也都会使用 class 了,class 关键字分担了 function 的部分任务。
以上所述就是本文的全部内容了,希望大家能够喜欢。
有用 | 无用
var function 我们知道 JS 不象其它语言 Java、Ruby等,它用来命名变量的只有关键字 var,不论何种类型数据都用 var 声明,当然弱类型并不代表该语言没有类型,它的类型在运行时(根据不同运算符)会隐式转换。而其它语言如Java,光声明数字的关键字就有 int、 float、double、long。
// JS
var num1 = 10; // 整数
var num2 = 10.1; // 浮点数
var str = 'John'; // 字符串
var boo = false; // 布尔
var obj = {}; // 对象
// Java
int num1 = 10;
double num2 = 10.2;
String str = "John";
Boolean boo = false;
JS 里标识符除了使用 var 产生,还有一个 function 关键字也可以产生标识符。function 类型声明的标识符的可能是函数、方法或构造器(类)。
// functions
function fetchData(url, param) {
// ...
}
// methods
var obj = {
getUrl: function() {
}
};
// class
function Person(name, age) {}
Person.prototype = {
}
二、ES6时代
var function let const class 可以看到,ES6 增加了3个可以产生标识符的关键字 let/const/class。let/const 用来声明变量,class 用来定义类。
// 定义普通变量
let name = 'John';
for (let i = 0; i < arr.length; i++) {
}
if (boo) {
let obj = {};
...
}
// 定义常量
const PI = 3.1415926;
const $el = $('.nav');
// 定义类
class Point {
constructor(x, y) {
this.x = x;
this.y = y;
}
toString() {
return '('+this.x+', '+this.y+')';
}
}
ES6时代,可以想象我们的代码风格里应该是 “少var多let”,let 和 const 都具有块级作用域,且不会发生变量提升。而声明类,也都会使用 class 了,class 关键字分担了 function 的部分任务。
以上所述就是本文的全部内容了,希望大家能够喜欢。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- 详解JavaScript中Date.UTC()方法的使用
- JavaScript中的parse()方法使用简介
- Javascript中setTimeOut和setInterval的定时器用法
- jQuery插件datepicker 日期连续选择
- JavaScript中的toUTCString()方法使用详解
- 简介JavaScript中toTimeString()方法的使用
- JavaScript中string对象
- JavaScript中用toString()方法返回时间为字符串
- ECMAScript6中Map/WeakMap详解
- JavaScript中Date.toSource()方法的使用教程
- ECMAScript6中Set/WeakSet详解
- JavaScript中的toLocaleDateString()方法使用简介
- ECMAScript6块级作用域及新变量声明(let)
- JavaScript中的toDateString()方法使用详解
- ECMAScript6新增值比较函数Object.is
- ECMAScript6函数剩余参数(Rest Parameters)
- ECMAScript6函数默认参数
- 在JavaScript中操作时间之setYear()方法的使用
- 简介JavaScript中setUTCSeconds()方法的使用