首页
技术笔记
网址导航
Json在线解析
二维码
Ip地址查询
在线流程图
新用户注册
|
会员登录
在线工具
开发笔记
毒鸡汤
网址导航
免费在线流程图
2赞
211
当前位置:
开发笔记
>
编程语言
> 正文
不错的JS中变量相关的细节分析_javascript技巧
作者:地之南_816 | 2021-08-16 16:02
不错的JS中变量相关的细节分析
这里讨论一下我对Javascript中变量相关细节的认识,有不当之处欢迎来批。
一、变量的类型
Javascript和Java、C这些语言不同,它是一种无类型、弱检测的语言。它对变量的定义并不需要声明变量类型,我们只要通过赋值的形式,可以将各种类型的数据赋值给同一个变量。例如:
i=100;//Number类型
i="variable";//String类型
i={x:4};//Object类型
i=[1,2,3];//Array类型
JS的这种特性虽然让我们的编码更加灵活,但也带来了一个弊端,不利于Debug,编译器的弱检测让我们维护冗长的代码时相当痛苦。
二、变量的声明
JS中变量申明分显式申明和隐式申明。
var i=100;//显式申明
i=100;//隐式申明
在函数中使用var关键字进行显式申明的变量是做为局部变量,而没有用var关键字,使用直接赋值方式声明的是全局变量。
当我们使用访问一个没有声明的变量时,JS会报错。而当我们给一个没有声明的变量赋值时,JS不会报错,相反它会认为我们是要隐式申明一个全局变量,这一点一定要注意。
三、全局变量和局部变量
当JS解析器执行时,首先就会在执行环境里构建一个全局对象,我们定义的全局属性就是做为该对象的属性读取,在顶层代码中我们使用this关键字和window对象都可以访问到它。而函数体中的局部变量只在函数执行时生成的调用对象中存在,函数执行完毕时局部变量即刻销毁。因此在程序设计中我们需要考虑如何合理声明变量,这样既减小了不必要的内存开销,同时能很大程度地避免变量重复定义而覆盖先前定义的变量所造成的Debug麻烦。
四、变量作用域
任何程序语言中变量的作用域都是一个很关键的细节。JS中变量的作用域相对与JAVA、C这类语言显得更自由,一个很大的特征就是JS变量没有块级作用域,函数中的变量在整个函数都中有效,运行下面代码:
输出结果为0 1 0,从上面就可以证明JS如果用var在函数体中声明变量,那么此变量在且只在该函数体内有效,函数运行结束时,本地变量即可销毁了。
由于上面的这个JS特性,还有一个关键的问题需要注意。此前一直使用ActionScript,虽然它和JS都是基于ECMA标准的,但在这里还是略有不同的。例如下面代码:
你可能认为输出结果是0 0 1 0,事实上在AS中确实是这样的,而在JS中的输入却是0 undefined 1 0,为何会这样了?刚才我们说到了JS函数体中声明的本地变量在整个函数中都有效,因此在上面代码中var i = 1 ;在inner函数中都有效,实际上显式声明的变量i是在预编译时就已经编译到调用对象中了,不同于隐式声明变量在解释时才被定义为全局变量,只是在调用outPut(i)时,还没有将它初始化变量,此时的本地变量i是未赋值变量,而不是未定义变量,因此输出了undefined。上面的代码等效于下面代码:
function inner(){
var i; //定义但不赋值
outPut(i); //undefiend
i=1;
outPut(i); //1
}
为了避免上面的这类问题,因此在函数开始位置集中做函数声明是一个极力推荐的做法。
五、基本类型和引用类型
JS不同于JAVA、C这些语言,在变量申明时并不需要声明变量的存储空间。变量中所存储的数据可以分为两类:基本类型和引用类型。其中数值、布尔值、null和undefined属于基本类型,对象、数组和函数属于引用类型。
基本类型在内存中具有固定的内存大小。例如:数值型在内存中占有八个字节,布尔值只占有一个字节。对于引用型数据,他们可以具有任意长度,因此他们的内存大小是不定的,因此变量中存储的实际上是对此数据的引用,通常是内存地址或者指针,通过它们我们可以找到这个数据。
引用类型和基本类型在使用行为上也有不同之处:
对基本类型b进行赋值时,实际上是又开辟了一块内存空间,因此改变变量a的值对变量b没有任何影响。
上面是对引用类型的变量赋值,实际上他们传递的是对内存地址的引用,因此对a_array和b_array的存取,实际上都是操作的同一块内存区域。如果希望重新分配内存空间存储引用型变量,那么我就需要使用克隆方法或者自定义方法来复制引用变量的数据。
推荐阅读
程序员
将因子转换为原始数值
如何解决《将因子转换为原始数值》经验,为你挑选了0个好方法。 ...
[详细]
程序员
重写System.out.print语句要容易一些
如何解决《重写System.out.print语句要容易一些》经验,为你挑选了3个好方法。 ...
[详细]
程序员
为什么递归函数的输出为0?
如何解决《为什么递归函数的输出为0?》经验,为你挑选了1个好方法。 ...
[详细]
程序员
JS图表库,允许部分着色y轴
如何解决《JS图表库,允许部分着色y轴》经验,为你挑选了1个好方法。 ...
[详细]
程序员
如何在bitbucket wiki的markdown中逃避"@"
如何解决《如何在bitbucketwiki的markdown中逃避"@"》经验,为你挑选了1个好方法。 ...
[详细]
程序员
在Leaflet LayerGroup中查找特定图层,其中图层是多边形
如何解决《在LeafletLayerGroup中查找特定图层,其中图层是多边形》经验,为你挑选了1个好方法。 ...
[详细]
程序员
Redshift使用Grant或Canned ACL卸载
如何解决《Redshift使用Grant或CannedACL卸载》经验,为你挑选了0个好方法。 ...
[详细]
程序员
单击Button时UITextField不会结束编辑(委托textFieldDidEndEditing)
如何解决《单击Button时UITextField不会结束编辑(委托textFieldDidEndEditing)》经验,为你挑选了1个好方法。 ...
[详细]
程序员
如何使用OpenCV 3.0 StereoSGBM和PCL生成一对立体图像的有效点云表示
如何解决《如何使用OpenCV3.0StereoSGBM和PCL生成一对立体图像的有效点云表示》经验,为你挑选了1个好方法。 ...
[详细]
程序员
在后台运行时查看随机ngrok URL
如何解决《在后台运行时查看随机ngrokURL》经验,为你挑选了2个好方法。 ...
[详细]
程序员
jQuery/javascript event.timestamp不起作用
如何解决《jQuery/javascriptevent.timestamp不起作用》经验,为你挑选了1个好方法。 ...
[详细]
程序员
设置应用程序图标(Xcode 7)
如何解决《设置应用程序图标(Xcode7)》经验,为你挑选了1个好方法。 ...
[详细]
程序员
使用本地帐户使用安全的ASP Net 5 web api
如何解决《使用本地帐户使用安全的ASPNet5webapi》经验,为你挑选了0个好方法。 ...
[详细]
程序员
Symfony Config Treebuilder
如何解决《SymfonyConfigTreebuilder》经验,为你挑选了0个好方法。 ...
[详细]
程序员
c枚举的重要性(typedef enum)
如何解决《c枚举的重要性(typedefenum)》经验,为你挑选了2个好方法。 ...
[详细]
程序员
使用Typescript 1.7从Angular 2模块导入类时遇到麻烦
如何解决《使用Typescript1.7从Angular2模块导入类时遇到麻烦》经验,为你挑选了1个好方法。 ...
[详细]
程序员
现在将从Swift 3中删除C-Style for循环,这是一种不执行循环的简洁方法?
如何解决《现在将从Swift3中删除C-Stylefor循环,这是一种不执行循环的简洁方法?》经验,为你挑选了2个好方法。 ...
[详细]
程序员
如何通过Swift Package Manager在Xcode中安装Package
如何解决《如何通过SwiftPackageManager在Xcode中安装Package》经验,为你挑选了2个好方法。 ...
[详细]
程序员
Javascript中的实例与引用vs对象
如何解决《Javascript中的实例与引用vs对象》经验,为你挑选了1个好方法。 ...
[详细]
程序员
AWS cli查询以获取具有特定源名称的Cloudfront"域名"
如何解决《AWScli查询以获取具有特定源名称的Cloudfront"域名"》经验,为你挑选了1个好方法。 ...
[详细]
吐了个 "CAO" !
吐个槽吧,看都看了
会员登录
|
用户注册
地之南_816
这个屌丝很懒,什么也没留下!
关注作者
Tags | 热门标签
actionscrip
bash
c#
c++
c语言
erlang
flutter
go
golang
java
javascript
lua
node.js
perl
php
python
scala
typescript
RankList | 热门文章
1
句子的情感分析-正面,负面和中性
2
为不透明度和体积编写关键帧插入的脚本
3
与Android 6.0的Adb wifi连接
4
控制isOpen in angular ui bootstrap
5
新Azure门户中的"下载发布配置文件"在哪里?
6
Prototype构造函数上下文中的JavaScript类型检查和异常?
7
来自splm的乳胶回归表
8
在OS X上将项目迁移到Xcode 7.2 El Capitan打破了构建
9
iOS 9.2缺少常规设置中的配置文件部分
10
docker:致命错误无法创建锁定文件:错误的文件描述符(9)
11
ES6循环依赖
12
如何创建在线SignalR服务器
13
当你有一个额外的变量时,在R中循环以创建许多图
14
xquery从外部xs:string变量(basex)插入节点
15
Django 1.9:我应该避免在`django.setup()`中导入模型吗?
16
如何遍历循环内的列表
17
如何正确合并集合中模型的输出?
18
将工作日志发布到JIRA时需要哪些字段?
19
在服务Web和API的Rails应用程序中正确使用protect_from_forgery
20
当项目有复选框时,RecyclerView项目不显示涟漪/触摸反馈
DevBox开发工具箱 | 专业的在线开发工具网站
京公网安备 11010802040832号
|
京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有