JavaScript学习小结(一)——JavaScript入门基础


Posted in Javascript onSeptember 02, 2015

一、JavaScript语言特点

1.1、JavaScript是基于对象和事件驱动的(动态的)

它可以直接对用户或客户输入做出响应,无须经过Web服务程序。它对用户的响应,是采用以事件驱动的方式进行的。所谓事件驱动,就是指在主页中执行了某种操作所产生的动作,就称为“事件”。比如按下鼠标,移动窗口,选择菜单等都可以视为事件。当事件发生后,可能会引起相应的事件响应。

1.2、JavaScript是跨平台的

JavaScript是依赖于浏览器本身的,与操作系统无关。

二、JavaScript变量

2.1、定义变量

在定义变量时,统一使用"var 变量名"表示,例如:var str;甚至可以省略var这个关键字

2.2、JavaScript变量的类型如何决定

JavaScript中变量的数据类型是由JS引擎决定的

var name="孤傲苍狼";//name是string类型
 var age=;//age是number类型
 var flag=true;//flag是boolean类型
 var email;//email只是声明,没有赋值,因此代表的类型是"undefined",也就是无法确定
 name=;//name自动变成了number类型

2.3、使用typeof关键字查看变量代表的具体数据类型

typeof 运算符有一个参数,即要检查的变量或值。例如:

var sTemp = "test string";
 alert (typeof sTemp);  //输出 "string"
 alert (typeof );  //输出 "number"

对变量或值调用typeof运算符将返回下列值之一:

undefined - 如果变量是 Undefined 类型的

boolean - 如果变量是 Boolean 类型的

number - 如果变量是 Number 类型的

string - 如果变量是 String 类型的

object - 如果变量是一种引用类型或 Null 类型的

测试代码:

<script type="text/javascript">
   var name="孤傲苍狼";//name是string类型
   alert("name是"+typeof name+"类型");
   var age=;//age是number类型
   alert("age是"+typeof age+"类型");
   var flag=true;//flag是boolean类型
   alert("flag的类型是:"+typeof flag);
   name=;//name自动变成了number类型
   alert("name变量重新赋值后,name的数据类型变成了:"+typeof name);
   var email;//email只是声明,没有赋值,因此代表的类型是"undefined",也就是无法确定
   alert("email的类型是:"+typeof email );
   var a=null;
 /*
 为什么 typeof 运算符对于 null 值会返回 "Object"。
 这实际上是 JavaScript 最初实现中的一个错误,然后被 ECMAScript 沿用了。现在,null 被认为是对象的占位符,从而解释了这一矛盾,但从技术上来说,它仍然是原始值。
 */
   alert("a是"+typeof a +"类型");
  </script>

运行结果:

JavaScript学习小结(一)——JavaScript入门基础

 三、JavaScript数据类型

JavaScript学习小结(一)——JavaScript入门基础

JavaScript包含两种不同数据类型:基本数据类型和引用数据类型。基本类型指的是简单的数据,引用类型指由多个值构成的对象。当我们把值赋值给一个变量时,解析器首先要做的就是确认这个值是基本类型值还是引用类型值。

3.1、基本数据类型

常见的五种基本数据类型:

Boolean
Number
String
Undifined
Null

这五种基本数据类型可以直接操作保存在变量中的实际值。

3.1.1、数值类型(Number)和布尔类型(Boolean)

看下面的代码:

<script type="text/javascript">
   var a = ;
   var b = a;
     b = ;
   alert("a="+a);//打印a=
   
   var b = true;
   var b = b;
     b = false;
   alert("b="+b);//打印b=true
 </script>

 运行结果:

JavaScript学习小结(一)——JavaScript入门基础

从运行结果可以看出,b的值是a值的一份拷贝,虽然,两个变量的值是相等,但是两个变量保存两不同的基本数据类型值。b只是保存了a复制的一个副本。所以,当b的值改变成20时,a的值依然是10。两个Boolean变量b1和b2同样是基本数据类型,同样保存两个不同的基本数据据类型值,b2保存1复制的一个副本。所以,当b2的值改变成false时,b1的值依然是true。

下图演示了这种基本数据类型赋值的过程:

栈内存

 JavaScript学习小结(一)——JavaScript入门基础

3.1.2、字符串类型(String)

JavaScript中的字符串String一个特殊的基本数据类型,在很多语言中,String是以对象的形式表示的,但在JavaScript里,String是当作一种基本数据类型,是通值传递的方式来操作。但它是一个比较特殊的基本类型。

看下面例子:

<script type="text/javascript">
   var strA = "这是字符串";
   var strB = strA;
     strA = "这是另外一个字符串";
     alert("strB="+strB);
 </script>

运行结果:

JavaScript学习小结(一)——JavaScript入门基础

从运行结果可以看到,仿佛strA通过值传递的方式复制了一份给了strB。当strA改变的时候,strB并没有改变,似乎我们已经可以下结论,String就是个基本数据类型。

可是,因为String是可以任意长度的,通过值传递,一个一个的复制字节显示效率依然很低,看起来String也可以当作引用类型。

看下面例子:

var a = "myobject";
 a.name = "myname";//为字符串a动态添加name属性
 alert("a.name="+a.name); //访问a的name属性,

结果显示:a.name=undefined

运行结果:

JavaScript学习小结(一)——JavaScript入门基础

运行结果显示,String无法当作一个对象来处理。这也证明了一点:基本类型虽然也可以添加属性,也不会报错,经测试添加完之后却是无法访问的,实际上,javascript里的String是不可以改变的,javascript也没有提供任何一个改变字符串的方法和语法。

看下面的例子:

var b = "myobject";
 b = b.substring(,);
 alert("b="+b); // b=bj

运行结果:

JavaScript学习小结(一)——JavaScript入门基础

这样做,没并有改变String字符串"myobject",只b引用了另一个字符串"bj","myobject"被回收了。

所以可以这样讲,String实际上并不符合上面两种数据类型分类。它是具有两方面属性介于两都之间的一种特殊类型。

3.1.3、Null 类型

Null类型只有一个专用值 null,值 undefined 实际上是从值 null 派生来的,因此 ECMAScript 把它们定义为相等的。

<script type="text/javascript">
    alert("null == undefined的结果是:"+(null == undefined)); //输出 "true"
  </script>

运行结果:

JavaScript学习小结(一)——JavaScript入门基础

尽管这两个值相等,但它们的含义不同。undefined 是声明了变量但未对其初始化时赋予该变量的值,null 则用于表示尚未存在的对象(typeof 运算符对于 null 值会返回 "Object"。)。如果函数或方法要返回的是对象,那么找不到该对象时,返回的通常是 null。

3.1.4、Undefined 类型

Undefined 类型只有一个值,即 undefined。当声明的变量未初始化时,该变量的默认值是 undefined。

var oTemp;

前面一行代码声明变量 oTemp,没有初始值。该变量将被赋予值 undefined,即 undefined 类型的字面量。可以用下面的代码段测试该变量的值是否等于 undefined:

<script type="text/javascript">
   var oTemp;
   alert("oTemp == undefined的结果是:"+(oTemp == undefined));//输出 "true"
  </script>

运行结果:

JavaScript学习小结(一)——JavaScript入门基础

运行结果显示 "true",说明这两个值确实相等。

可以用 typeof 运算符显示该变量所代表的的数据类型是undefined类型

<script type="text/javascript">
   var oTemp;
   alert("typeof oTemp的结果是:"+typeof oTemp); //输出 "undefined"
  </script>

JavaScript学习小结(一)——JavaScript入门基础

值 undefined 并不同于未定义的值。但是,typeof 运算符并不真正区分这两种值。考虑下面的代码:

<script type="text/javascript">
   var oTemp;
   alert("oTemp变量有声明,typeof oTemp的结果是:"+typeof oTemp); //输出 "undefined"
   alert("oTemp变量没有声明,typeof oTemp的结果是:"+typeof oTemp); //输出 "undefined"
  </script>

运行结果:

JavaScript学习小结(一)——JavaScript入门基础

两个变量输出的都是 "undefined",即使只有变量 oTemp2 从未被声明过。如果对oTemp2 使用除 typeof 之外的其他运算符的话,会引起错误,因为其他运算符只能用于已声明的变量上。

下面的代码将引发错误:

var oTemp;
 alert(oTemp == undefined);//'oTemp' 未定义

当函数无明确返回值时,返回的也是值 "undefined",如下所示:

function testFunc() { 
   //这是一个空函数,没有返回值
 }
 alert("testFunc() == undefined的结果是:"+(testFunc() == undefined)); //输出 "true"

运行结果:

JavaScript学习小结(一)——JavaScript入门基础

3.2、引用数据类型

javascript引用数据类型是保存在堆内存中的对象,JavaScript不允许直接访问堆内存空间中的位置和操作堆内存空间,只能通过操作对象在栈内存中的引用地址。所以引用类型的数据,在栈内存中保存的实际上是对象在堆内存中的引用地址。通过这个引用地址可以快速查找到保存在堆内存中的对象。

看下面的例子:

<script type="text/javascript">
   var obj = new Object();
   var obj = obj;
   obj.name = "孤傲苍狼";
   alert(obj.name); // 孤傲苍狼
 </script>

运行结果:

JavaScript学习小结(一)——JavaScript入门基础

由上面例子,我们声明了一个引用数据类型变量obj1,并把它赋值给了另外一个引用数据类型变量obj2。当我们obj2添加了一个name属性并赋值" 孤傲苍狼"。obj1同样拥有了和obj2一样的name属性。说明这两个引用数据类型变量指向同一个对象。obj1赋值给obj2,实际只是把这个对象在栈内存的引用地址复制了一份给了obj2,但它们本质上共同指向了堆内存中的同一个对象。

下面我们来演示这个引用数据类型赋值过程

JavaScript学习小结(一)——JavaScript入门基础

自然,给obj2添加name属性,实际上是给堆内存中的对象添加了name属性,obj2和obj1在栈内存中保存的只是堆内存对象的引用地址,虽然也是拷贝了一份,但指向的对象却是同一个。故而改变obj2引起了obj1的改变。

一般而言,基本数据类型是由固定数目的字节组成,这些字节可以在解析器的较底层进行操作,比如Number和 Boolean;而引用数据类型,可以包含任意数目的属性和元素,因此它们无法像基本数据类型那样很容易的操作。

由于,引用数据类型的值是会发生变化的, 所以通过跟基本数据类型一样的值传递方式,也就没什么意义了,因为会牵涉到大量的内存的复制和比较,效率太低。所以引用数据类型是通过引用传递方式,实际传递的只是对象的一个地址。

比如Array和Function,因为它们都是特殊的对象所以它们都是引用类型。另外,引用类型是可以添加属性,基本类型虽然也可以添加属性,也不会报错,经测试添加完之后却是无法访问的。

Javascript 相关文章推荐
jquery插件制作 提示框插件实现代码
Aug 17 Javascript
JavaScript栏目列表隐藏/显示简单实现
Apr 03 Javascript
js 实现菜单左右滚动显示示例介绍
Nov 21 Javascript
Js表格万条数据瞬间加载实现代码
Feb 20 Javascript
JavaScript怎么判断图片是否加载完成以便获取其尺寸
May 08 Javascript
对vue.js中this.$emit的深入理解
Feb 23 Javascript
使用Angular CLI生成 Angular 5项目教程详解
Mar 18 Javascript
javascript数组去重方法总结(推荐)
Mar 20 Javascript
Vue的双向数据绑定实现原理解析
Feb 17 Javascript
JavaScript实现拖拽效果
Mar 16 Javascript
vue中全局路由守卫中替代this操作(this.$store/this.$vux)
Jul 24 Javascript
vuex中遇到的坑,vuex数据改变,组件中页面不渲染操作
Nov 16 Javascript
基于dropdown.js实现的两款美观大气的二级导航菜单
Sep 02 #Javascript
JavaScript对象学习小结
Sep 02 #Javascript
JS实现可点击展开与关闭的左侧广告代码
Sep 02 #Javascript
jquery实现华丽的可折角广告代码
Sep 02 #Javascript
javascript学习总结之js使用技巧
Sep 02 #Javascript
jQuery实现固定在网页顶部的菜单效果代码
Sep 02 #Javascript
自定义刻度jQuery进度条及插件
Sep 02 #Javascript
You might like
php数据结构 算法(PHP描述) 简单选择排序 simple selection sort
2011/08/09 PHP
Google排名中的10个最著名的 JavaScript库
2010/04/27 Javascript
javascript使用location.search的示例
2013/11/05 Javascript
js document.write()使用介绍
2014/02/21 Javascript
JavaScript 模块化编程(笔记)
2015/04/08 Javascript
JavaScript实现复制内容到粘贴板代码
2016/03/31 Javascript
js一维数组、多维数组和对象的混合使用方法
2016/04/03 Javascript
jQuery判断是否存在滚动条的简单方法
2016/09/17 Javascript
简单三步实现报表页面集成天气
2016/12/15 Javascript
Zepto实现密码的隐藏/显示
2017/04/07 Javascript
springmvc接收jquery提交的数组数据代码分享
2017/10/28 jQuery
解决JavaScript中0.1+0.2不等于0.3问题
2018/10/23 Javascript
解决cordova+vue 项目打包成APK应用遇到的问题
2019/05/10 Javascript
纯js实现无缝滚动功能代码实例
2020/02/21 Javascript
[10:18]2018DOTA2国际邀请赛寻真——Fnatic能否笑到最后?
2018/08/14 DOTA
python错误:AttributeError: 'module' object has no attribute 'setdefaultencoding'问题的解决方法
2014/08/22 Python
Python基于pillow判断图片完整性的方法
2016/09/18 Python
python3设计模式之简单工厂模式
2017/10/17 Python
解决vscode python print 输出窗口中文乱码的问题
2018/12/03 Python
python变量赋值方法(可变与不可变)
2019/01/12 Python
django的ORM操作 增加和查询
2019/07/26 Python
pyCharm 设置调试输出窗口中文显示方式(字符码转换)
2020/06/09 Python
Pycharm快捷键配置详细整理
2020/10/13 Python
python uuid生成唯一id或str的最简单案例
2021/01/13 Python
CSS3中的注音对齐属性ruby-align用法指南
2016/07/01 HTML / CSS
英国高档时尚男装购物网站:MR PORTER
2016/08/09 全球购物
英国鲜花递送:Blossoming Gifts
2020/07/10 全球购物
学生会主席就职演讲稿
2014/01/14 职场文书
股东授权委托书范本
2014/09/13 职场文书
反腐倡廉剖析材料
2014/09/30 职场文书
党员活动总结
2015/02/04 职场文书
2015年加油站工作总结
2015/05/13 职场文书
2015年服务员个人工作总结
2015/05/27 职场文书
总经理聘用协议书
2015/09/21 职场文书
浅谈Python数学建模之数据导入
2021/06/23 Python
对讲机的最大通讯距离是多少
2022/02/18 无线电