详解javascript的变量与标识符


Posted in Javascript onJanuary 04, 2016

一、变量

从字面上看,变量是可变的量;从编程角度讲,变量是用于存储数据的容器

详解javascript的变量与标识符

1.1变量特性

javascript中的变量是松散类型的,可以保存任何类型的数据。由于不存在定义某个变量必须要保存何种数据类型值的规则,变量的值及其数据类型可以在脚本的生命周期内改变 

1.2变量命名

变量可以任意取名,但必须遵循命名规则:

[1]第一个字符必须是字母、下划线或美元符号。其他字符可以是字母、下划线、美元符号或数字

//错误示范
 6num //开头不能用数字
 %sum //开头不能用除(_ $)外特殊符号,如(% + /等)
 sum+num //开头中间不能使用除(_ $)外特殊符号,如(% + /等)

[2]字符中的字母可以包括拓展的ASCII或Unicode字母字符,也可以使用中文

[3]不能使用关键字、保留字、true、false和null

[4]变量对大小写敏感

[5]标识符应采用小驼峰格式,第一位应该是数据的类型,常见的标识如下:

数组

    a    Array

   aItems
布尔值   

    b    Boolean

  bIsComplete
浮点数   

    f

Float

    fPrice
函数

   fn    Function

fnHandler
整数

    i

Integer

iItemCount
对象

   o

Object

  oDIv1
正则表达式       re    RegExp

  reEmailCheck
字符串

      s

String

  sUserName
变量

    v

Variant

vAnything     

1.3变量声明
声明格式为: var 变量名;

var num;//声明一个变量
var num1,num2;//声明多个变量

用var操作符定义的变量将成为定义该变量的作用域中的局部变量。若省略var操作符,可以创建一个全局变量,但在严格模式下会抛出 ReferenceError错误

var num1=1;
num2=2;//在严格模式下会报错
num3;//报错

如果重新声明 JavaScript 变量,该变量的值不会丢失

var carname="Volvo";
console.log(carname);//Volvo
var carname;
console.log(carname);//Volvo

1.4声明提升

javascript中的变量声明会提升到所有函数和语句之前,但提升后的变量将返回undefined,因为只是声明提升,赋值操作并没有提升

console.log(myvar); // undefined
var myvar = "local value";
console.log(myvar); // "local value"

1.5变量赋值

使用"="给变量赋值,也就是存储内容。变量可以在声明时赋值,但不能有其他操作,如+=、-=等

var num = 5;
//上下是等价的
var num;
num = 5;
var a = 2;//正确
var a += 2;//错误
var a = 2++;//错误,++只能用于变量,不能用于常量

二、标识符

标识符是指变量、函数、属性的名字,或者函数的参数 

2.1标识符命名

命名规则同变量命名规则,对于不符合命名规则的属性如border-color应写为大括号方式[borderColor] 

2.2标识符解析

标识符解析是沿着作用域链一级一级地搜索标识符的过程。搜索过程始终从作用域链的前端开始,然后逐级地向后回溯,直到找到标识符为止。

[1]如果局部环境中存在着同名标识符,就不会使用父环境中的标识符

[2]如果找不到标识符,表示标识符尚未声明,通常会导致错误发生

[3]JavaScript引擎在优化标识符查询方面做得不错,访问父环境和局部环境的标识符的时间差别可以忽略不计

var num = 1;
function test(){
 num = 2;
 console.log(num);//2
 console.log(number);//报错
}
test();

以上就是关于javascript的变量与标识符的相关内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
使用jQuery不判断浏览器高度解决iframe自适应高度问题
Dec 16 Javascript
jQuery实现首页顶部可伸缩广告特效代码
Apr 15 Javascript
js操作css属性实现div层展开关闭效果的方法
May 11 Javascript
jQuery插件echarts实现的单折线图效果示例【附demo源码下载】
Mar 04 Javascript
js数字滑动时钟的简单实现(示例讲解)
Aug 14 Javascript
angular2 ng2 @input和@output理解及示例
Oct 10 Javascript
利用VS Code开发你的第一个AngularJS 2应用程序
Dec 15 Javascript
js+css实现红包雨效果
Jul 12 Javascript
layui 设置table 行的高度方法
Aug 17 Javascript
你了解vue3.0响应式数据怎么实现吗
Jun 07 Javascript
uniapp实现横向滚动选择日期
Oct 21 Javascript
vue-cil之axios的二次封装与proxy反向代理使用说明
Apr 07 Vue.js
bootstrap实现弹窗和拖动效果
Jan 03 #Javascript
基于javascript实现窗口抖动效果
Jan 03 #Javascript
理解jquery事件冒泡
Jan 03 #Javascript
实例讲解避免javascript冲突的方法
Jan 03 #Javascript
详解js中class的多种函数封装方法
Jan 03 #Javascript
js中利用tagname和id获取元素的方法
Jan 03 #Javascript
信息页文内画中画广告js实现代码(文中加载广告方式)
Jan 03 #Javascript
You might like
按上下级层次关系输出内容的PHP代码
2010/07/17 PHP
PHP模糊查询的实现方法(推荐)
2016/09/06 PHP
2017年最新PHP经典面试题目汇总(上篇)
2017/03/17 PHP
PHP防止sql注入小技巧之sql预处理原理与实现方法分析
2019/12/13 PHP
Laravel 验证码认证学习记录小结
2019/12/20 PHP
php7 list()、session及其他模块的修改实例分析
2020/05/25 PHP
jquery.ui.draggable中文文档
2009/11/24 Javascript
Jquery 插件开发笔记整理
2011/01/17 Javascript
Node.js的包详细介绍
2015/01/14 Javascript
JS实现可拖曳、可关闭的弹窗效果
2015/09/26 Javascript
VUE长按事件需求详解
2017/10/18 Javascript
利用ES6实现单例模式及其应用详解
2017/12/09 Javascript
vue项目中api接口管理总结
2018/04/20 Javascript
vue实现div拖拽互换位置
2020/07/29 Javascript
浅析JavaScript异步代码优化
2019/03/18 Javascript
Webpack的Loader和Plugin的区别
2020/11/09 Javascript
[03:40]DOTA2亚洲邀请赛小组赛第二日 赛事回顾
2015/01/31 DOTA
python用字典统计单词或汉字词个数示例
2014/04/22 Python
python批量制作雷达图的实现方法
2016/07/26 Python
python中模块查找的原理与方法详解
2017/08/11 Python
python三大神器之fabric使用教程
2019/06/10 Python
Ubuntu下Anaconda和Pycharm配置方法详解
2019/06/14 Python
selenium2.0中常用的python函数汇总
2019/08/05 Python
Pytorch 实现冻结指定卷积层的参数
2020/01/06 Python
tensorflow指定GPU与动态分配GPU memory设置
2020/02/03 Python
Html5移动端适配IphoneX等机型的方法
2019/06/25 HTML / CSS
JD Sports西班牙:英国领先的运动服装公司
2020/01/06 全球购物
乐高瑞士官方商店:LEGO CH
2020/08/16 全球购物
Perfume’s Club美国官网:西班牙第一家在线美容店
2020/06/10 全球购物
运动会广播稿500字
2014/01/28 职场文书
追悼会子女答谢词
2014/01/28 职场文书
秋季运动会广播稿大全
2014/02/17 职场文书
学校运动会广播稿范文
2014/10/02 职场文书
办公室务虚会发言材料
2014/10/20 职场文书
安全生产学习心得体会
2016/01/18 职场文书
MySql数据库触发器使用教程
2022/06/01 MySQL