Javascript 有两中类型:原始类型和对象类型。

原始类型包括:数字,字符串,布尔值,null和undefined。其余的都是对象类型。

原始类型

数字。Javascript采用IEEE754标准定义的64为的浮点格式表示数字。实际操作则是基于32位整数。

字符串是一组由16位值组成的不可变的有序序列。只要引用字符串的属性,Javascript就会将字符串值通过调用new String(string_name)的方式转换成对象,这个对象继承了字符的方法,并被用来处理属性的引用。比如:

var s="hello world";
var word=s.subString(s.indexOf(" ")+1, s.length);//使用字符串的属性,当引用结束时,新创建的对象就会销毁
<pre name="code" class="javascript">var s="test";
s.len=4;
var t=s.len;
alert(t);//输出undefined , 在读取字符串、数字和布尔值的属性值或方法时,表现的像对象一样,但是如果对其进行赋值,则会忽略:修改只是发生在临时对象身上,而这个临时对象并未继续保留下来

var s="test";
var s1=new String(s);
s1.len=4;
var t=s1.len;
alert(t);//输出4
alert(s==s1);//true
alert(s===s1);//false
alert(s.toUpperCase());//TEST 
alert(s);//test原来的字符串并没有改变,上面输出的是一个新的临时的字符串

布尔值只有两个值,true和false。

null是一个特殊的值用来描述“空”,是一个特殊的对象值,含义是“非对象”,但实际上用来表示数字、字符串和对象是“无值“的。

undefined用来表示更深层次的”空值“,表示变量没有初始化,要是查询对象属性或者数组元素的值时返回undefined则说明这个属性或元素不存在。如果函数没有返回任何值则返回undefined。undefined是预定义的全局变量,它的值是”未定义“。

对象类型

对象是属性的集合,每个属性都由“名/值对”(值可以是原始值,也可以使对象)构成。还有一个特殊的对象----函数。函数是与它相关联的可执行代码的对象,通过可执行函数来运行代码。对于Javascript函数来讲,最重要的是,它们都是真值,并且Javascript可以将它们当作普通对象来对待。如果函数用来初始化一个新建的对象,我们称之为构造函数。每个构造函数定义了一类对象-----有构造函数初始化的对象组成的集合。类可以看作是对象类型的子类型。Javascript核心语言定义了数组类(Array)、函数类(Function)、日期类(Date)、正则类(RegExp)、错误类(Error)。
Javascript对象是一种复合值:它是属性或者已命名值的集合。通过”."符合来引用属性值。当属性值是一个函数的时候,称其为方法。

Javascript有自己的内存管理机制,可以自动对内存进行回收。Javascript是一种面向对象的语言。这意味这我们不用全局的定义函数去操作不同类型的值。数据类型本身可以定义方法来使用值。
Javascript变量是无类型的,变量可以被赋予任何类型的值。使用var关键字来声明变量。采用词法作用域,不在任何函数内声明的变量是全局变量,全局可见;在函数内声明的变量是局部变量,只在声明的函数内可见。

比较

原始值的比较是值的比较。
对象的比较是非值的比较,即使两个对象包含同样的属性及相同的值。各个索引元素完全相等的两个数组也不相等。对象值都是引用。当且仅当引用同一个基对象时,它们才相等。

转换

对象转换为布尔值非常简单:都是true。
对象转为字符串比较复杂。所有的对象继承了两个转换方法。第一个是toString(),它的作用是返回一个反映这个对象的字符串。另一个是valueOf(),如果存在任意原始值就默认将对象转换为原始值,否则返回对象本身。
空数组会被转换为 数字0,单个元素的数组会转换为一个数字。数组继承了默认的valueOf()方法,找个方法返回一个对象而不是一个原始值,因此数组到数字的转换则调用tostring()方法。空数组转换为空字符串,空字符串转换为 0。

变量声明

变量的作用域是变量声明时的区域。在函数体内,局部变量的优先级高于全局变量。
作为属性的变量,实际上使定义了全局对象的一个属性。当使用var声明一个变量时,创建的这个属性时不可配置的,无法通过delete运算符删掉。


作用域链



操作符

按位与 &
按位或 |
按位异或 ^
按位非 ~
左移 <<
右移 >>
无符号右移 >>>


instanceOf




版权声明:本文为博主原创文章,未经博主允许不得转载。

Javascript类型的更多相关文章

  1. javascript类型与类型检测

    1.javascript类型: 注:包装对象:如"hello".length实际为js为我们隐式创建了一个String临时对象,去调用该对象的length属性,调用过后再将该临时对 ...

  2. javascript类型注意事项

    以下是javascript类型的注意事项: null:表示尚未存在的对象,注意,尽管尚未存在,也是个对象啊,所以用typeof检测一个null值变量的结果是Object:不过,为了便于写if语句,在j ...

  3. 谈谈JavaScript类型检测

      javascript内置的类型检测机制并非完全可靠.比如typeof操作符,并不能准确的判断数据是哪个类型,比如:数组和对象就不能通过typeof来区分. typeof [] ==="o ...

  4. Javascript类型检测

    原地址 http://www.cnblogs.com/fool/archive/2010/10/07/javascrpt.html 开门见山,我们先来看一下代码: var is = function ...

  5. JavaScript 类型浅解

    对于JavaScript 类型,可简单地概括为:相对于强类型语言来说,它是弱(松散)类型的语言:有基本类型和引用类型,他们是区别是一个有固定空间存在于栈内存中,一个没有固定空间保存在堆内存中并且在栈内 ...

  6. JavaScript类型和语法

    JavaScript类型和语法 一.类型 1.内置类型(null.undefined.boolean.number.string.object.symbol(es6中新增))(除对象之外,其它统称为基 ...

  7. JavaScript权威设计--JavaScript类型,值,变量(简要学习笔记三)

    1.负号是一元求反运算 如果直接给数字直接量前面添加负号可以得到他们的负值     2.JavaScript中的运算超出了最大能表示的值不会报错,会显示Infinity. 超出最小也不报错,会显示-I ...

  8. JavaScript类型判断instanceof与typeof对比

    经常有人会在JavaScript里写如下的方法: function checkType() { var s1 = 123; var s2 = "OK"; if (s1 instan ...

  9. JavaScript –类型之我晕

    每次写博我觉得取上恬当的题目比整篇行文都难,词量有限的情况下突然想到JavaScript拾遗应该会是一个非常文艺而夺目的博文题目,但我并没有急着使用,经验告诉我应该先去搜一下看有没有被用过.果不其然, ...

  10. JavaScript类型判断

    几种方法:typeof,instanceof,Object.prototype.toString,constructor,duck type ES6引入了一种新的原始数据类型Symbol,表示独一无二 ...

随机推荐

  1. python数据结构与算法——冒泡排序

    用两种方式实现,非递归和递归 直接上代码: 先是失败的递归方式,涉及到对象引用的问题: # Bad 想一想为啥不行? def bubblesort_rec_bad(A): if len(A)==1: ...

  2. import tf

    不知道为什么,tensorflow要最后import,否则会对matplotlib的imread产生影响,产生IO错误,异常莫名其妙

  3. RelativeLayout.LayoutParams.addRule()方法

    1.应用场景 在使用RelativeLayout布局的时候,通常在载入布局之前在相关的XML文件中进行静态设置即可.但是,在有些情况下,我们需要动态的设置布局 的属性,在不同条件下设置不同的布局排列方 ...

  4. 《统计推断(Statistical Inference)》读书笔记——第6章 数据简化原理

    在外行眼里统计学家经常做的一件事就是把一大堆杂七杂八的数据放在一起,算出几个莫名其妙的数字,然后再通过这些数字推理出貌似很靠谱的结论,简直就像是炼金术士用“贤者之石”把一堆石头炼成了金矿.第六章,应该 ...

  5. 修改pc机的mac地址 以及 mac地址的组成

    在"开始"菜单的"运行"中输入regedit,打开注册表编辑器,展开注册表到:HKEY_LOCAL_ MACHINE/System/CurrentControl ...

  6. (转)CVPR 2016 Visual Tracking Paper Review

    CVPR 2016 Visual Tracking Paper Review  本文摘自:http://blog.csdn.net/ben_ben_niao/article/details/52072 ...

  7. UIAutomator定位Android控件的方法

    UIAutomator各种控件定位的方法. 1. 背景 使用SDK自带的NotePad应用,尝试去获得在NotesList那个Activity里的Menu Options上面的那个Add note菜单 ...

  8. Func<T>与Action<T>委托泛型介绍

    .Net 3.5之后,微软推出了Func<T>与Action<T>泛型委托.进一步简化了委托的定义. Action<T>委托主要的表现形式如下: public de ...

  9. HTML 参考手册

    按字母顺序排列 New : HTML5 中的新标签. 标签 描述 <!--...--> 定义注释. <!DOCTYPE>  定义文档类型. <a> 定义锚. < ...

  10. webform 创建树

    using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Web.UI ...