JavaScript变量的认知

简介: 引入和许多编程语言一样,JS的变量也是一个可以等同为方程或者函数中那个“可变化的量”——X。不过在计算机的世界里,变量可以不仅仅是数字他可以包含我们上期提到的所有的数据类型。变量短暂存储了我们中间过程中所有的量,也正是由这些变量,我们构建出了当今这个丰富多彩的计算机世界……本期我们就一起来看看如何定义变量,包括申明、赋值、strict模式

引入

和许多编程语言一样,JS的变量也是一个可以等同为方程或者函数中那个“可变化的量”——X。

不过在计算机的世界里,变量可以不仅仅是数字

他可以包含我们上期提到的所有的数据类型。变量短暂存储了我们中间过程中所有的量,也正是由这些变量,我们构建出了当今这个丰富多彩的计算机世界……

本期我们就一起来看看如何定义变量,包括申明、赋值、strict模式


1. 变量的申明


JavaScript中变量是用一个变量名表示的,这个变量名的命名规则是

可以是大小写英文、数字、$_的组合。但不能以数字开头,也不能是JavaScript自带的保留字(也有人称为是关键字),如if、while等

符合以上条件的字符都可以是变量名。我们直接可以用var语句来申明一个变量——

var a; // 申明了变量a

我们用上面的语句就成功申明了一个变量a。但我们要注意,因为此时我们没有给a任何的值,所以此时a的值为undefined。既不是0也不是""(空字符串)


2. 变量的赋值


在JavaScript中,我们同其他编程语言一样,使用等号=给变量进行赋值。赋值规则是从右往左,即左边是变量名,右边是对应的值。我们可以把任意数据类型赋值给变量,且同一个变量可以反复赋值,并且和Python很像,重复赋值的可以是不同类型的变量,(不像C语言,变量数据类型是固定的)

var a = 100; // a的值是100,整数型
a = 'ABC'; // a变为字符串ABC

注意只能用var申明一次

我们把这类可以赋值不同数据类型给同一个变量的语言叫动态语言,C和JAVA这类变量本身数据类型固定的语言就是静态语言了


3. strict模式


有人说,同样是动态语言,Python直接赋值就可以了,都不用var之类的申明变量,JS可以这样吗?

很可惜,答案是可以的

为什么说是很可惜?因为JavaScript中如果不进行var申明就直接赋值,该变量就会被申明为全局变量——而JS是写前端的,如果你在一个页面的不同文件上不申明变量,那他们都会被定义为全局变量,这些全局变量会相互冲突,造成程序错误。

而用var申明的变量则会被限制住(一般限制在当前函数内),这样就可以减少冲突发生的可能性

所以JS官方出了一个strict模式,让使用者强制自己每个变量都用var申明过,否则会导致程序出错

启用这个模式的方法就是在JS第一行写上


'use strict'


但是要注意了,这里我们写的是一个字符串,有些低版本的浏览器会把它当做一个字符串执行,所以……

对前端人来说,要求配适所有浏览器可是比扣钱还恐怖


相关文章
|
2月前
|
JavaScript 前端开发
JavaScript如何判断变量undefined
JavaScript如何判断变量undefined
|
2月前
|
JavaScript 前端开发
JavaScript基础知识-变量的声明提前
关于JavaScript变量声明提前特性的基础知识介绍。
44 0
JavaScript基础知识-变量的声明提前
|
13天前
|
前端开发 JavaScript
如何在 JavaScript 中访问和修改 CSS 变量?
【10月更文挑战第28天】通过以上方法,可以在JavaScript中灵活地访问和修改CSS变量,从而实现根据用户交互、页面状态等动态地改变页面样式,为网页添加更多的交互性和动态效果。在实际应用中,可以根据具体的需求和场景选择合适的方法来操作CSS变量。
|
13天前
|
前端开发 JavaScript 数据处理
CSS 变量的作用域和 JavaScript 变量的作用域有什么不同?
【10月更文挑战第28天】CSS变量和JavaScript变量虽然都有各自的作用域概念,但由于它们所属的语言和应用场景不同,其作用域的定义、范围、覆盖规则以及与其他语言特性的交互方式等方面都存在明显的差异。理解这些差异有助于更好地在Web开发中分别运用它们来实现预期的页面效果和功能逻辑。
|
13天前
|
前端开发 JavaScript UED
如何使用 JavaScript 动态修改 CSS 变量的值?
【10月更文挑战第28天】使用JavaScript动态修改CSS变量的值可以为页面带来更丰富的交互效果和动态样式变化,根据不同的应用场景和需求,可以选择合适的方法来实现CSS变量的动态修改,从而提高页面的灵活性和用户体验。
|
2月前
|
存储 前端开发 JavaScript
前端基础(二)_JavaScript变量、JavaScript标识符、JavaScript获取元素、JavaScript的鼠标事件
本文介绍了JavaScript变量的声明和使用、标识符的命名规则、如何获取和操作HTML元素,以及JavaScript的鼠标事件处理,通过示例代码展示了这些基础知识点在实际开发中的应用。
43 2
前端基础(二)_JavaScript变量、JavaScript标识符、JavaScript获取元素、JavaScript的鼠标事件
|
25天前
|
JavaScript 前端开发
局部 JavaScript 变量
JavaScript 中,函数内部使用 `var` 声明的变量为局部变量,仅在函数内可见,函数执行完毕后被删除。全局变量则在函数外部声明,整个页面的脚本和函数均可访问,页面关闭后才被删除。未声明的变量赋值会自动成为 `window` 对象的属性,且在非严格模式下可被删除。
|
2月前
|
JavaScript 前端开发
js 变量作用域与解构赋值| 22
js 变量作用域与解构赋值| 22
|
1月前
|
JavaScript 前端开发
什么是JavaScript变量?
什么是JavaScript变量?
34 0
|
2月前
|
存储 JavaScript 前端开发