一:总体的类型系

基本类型:数字类型(number),字符串类型(string),布尔类型(boolean);

复合类型:对象(对象,函数,数组等);

无类型:null(有定义),undefined(未定义).

js中获取类型:typeof

声明类型统一用:var

基本类型又可以称为数据类型,每种数据类型都有相对应的对象类型(包装类型)。

包装类型的作用:提供属性,方法等功能。

number--Number

string--String

boolean--Boolean

var number=10;
number.toString();//number是一个基本类型,它又是如何能实现toString()方法的呢?

在数据操作的过程中,number在内存中创建临时的与之对应的包装类型,并执行toString方法,将结果返回,同时释放这个包装类型。

在JavaScript中判断等于和不等于有两种方式:

1.==和!=

只判断结果是否相同(存在隐式转换的问题)

2.===和!==

判断结果和类型是否都相同

var num=1;
var str="1"; num==str; //返回true
num===str;//返回false

二:三种基本的数据类型

1.string类型:字符串类型

  +;表示连接

var str1="Hello";
var str2="JavaScript"; var str=str1+str2;//str="Hello JavaScript"

length;字符串长度

var str="dennis";

var length=str.length;//length的值为6

  charAt(i);获得字符串中某一个位置的字符

var str="dennis";
var char=str.charAt(1);//char=e

  substring(StartIndex,EndIndex);获取子字符串,从开始位置到结束位置

  substr(StartIndex,Length);获取子字符串,从开始位置到指定长度的位置

var str="Hello JavaScript";
var str1=str.substring(0,6); //str1="Hello"
var str2=str.substr(2,6); //str2="llo Ja"

  split('|',数字);将字符串按某个字符分离,其中数字参数是可选的。

<script type="text/javascript">

var str="How are you doing today?"

document.write(str.split(" ") + "<br />")
document.write(str.split("") + "<br />")
document.write(str.split(" ",3)) </script>

结果:

How,are,you,doing,today?
H,o,w, ,a,r,e, ,y,o,u, ,d,o,i,n,g, ,t,o,d,a,y,?
How,are,you

2. number类型:数字类型

  number类型中有很多方法,参考 http://www.w3school.com.cn/jsref/jsref_obj_number.asp

  几种特殊的数字类型:NaN(不是一个数字的数字类型),判断可以用 isNaN();

            Infinity 无穷,判断可以用 isFinite();

var num=0/0;
alert(num); //输出NaN var num1=10/0;
alert(num1); //输出Infinity

  对应的包装类型Number

  Number.MAX_VALUE  //数字的最大值

  Number.MIN_VALUE  //数字的最小值

  Number.POSITIVE_INFINITY  //正无穷

  Number.NEGATIVE_INFINITY //负无穷

  document.write(Number.MAX_VALUE + "<br />");  //数字的最大值

    document.write(Number.MIN_VALUE + "<br />");  //数字的最小值

    document.write(Number.POSITIVE_INFINITY + "<br />");  //正无穷

    document.write(Number.NEGATIVE_INFINITY + "<br />"); //负无穷)

结果:

1.7976931348623157e+308
5e-324
Infinity
-Infinity

3.boolean类型:布尔类型

布尔(逻辑)只能有两个值:true 或 false。

对应的包装类型Boolean用法参见:http://www.w3school.com.cn/jsref/jsref_obj_boolean.asp

  

JavaScript的类型体系的更多相关文章

  1. JavaScript事件类型

    JavaScript事件类型 Web浏览器中可能发生的事件有很多类型.这里我将主要将下面几种常用的事件类型: UI事件 焦点事件 鼠标与滚轮事件 键盘与文本事件 复合事件 变动事件 HTML5事件 设 ...

  2. Flow: JavaScript静态类型检查工具

    Flow: JavaScript静态类型检查工具 Flow是Facebook出品的,针对JavaScript的静态类型检查工具.其代码托管在github之上,并遵守BSD开源协议. 关于Flow 它可 ...

  3. javascript 操作符类型隐性转换

    javascript 操作符类型隐性转换 (一).一元操作符只能操作一个值的操作符叫做一元操作符1.递增和递减操作符a. 在应用于一个包含有效数字字符的字符串时,先将其转换为数字值,再执行加减1的操作 ...

  4. javascript学习-类型判断

    javascript学习-类型判断 1.类型判断的的武器 javascript中用于类型判断的武器基本上有以下几种: 严格相等===,用来判断null,undefined,true,false这种有限 ...

  5. JavaScript的类型自动转换高级玩法JSFuck

    0 前言 最开始是不小心在微信公众号(程序员大咖)看到一篇JS的高逼格代码,然后通过里面的链接跳转到了JSFuck的wiki,就像顺着迷宫找宝藏的感觉,感叹JS的自动类型转换的牛逼. 1 样例 (!( ...

  6. 面向对象的JavaScript --- 动态类型语言

    面向对象的JavaScript --- 动态类型语言 动态类型语言与面向接口编程 JavaScript 没有提供传统面向对象语言中的类式继承,而是通过原型委托的方式来实现对象与对象之间的继承. Jav ...

  7. javascript 字典类型的使用

    javascript  字典类型的使用 1.使用Array: var arr = new Array(); arr["zs"] = "zhangsan"; ar ...

  8. javascript变量类型及作用域

    javascript变量类型及作用域 一.简介 变量类型 ECMAScript变量可能包含两种不同类型的数据值:基本类型和引用类型. 基本类型 基本类型指的是简单的数据段,5种基本数据类型:undef ...

  9. js课程 1-3 Javascript变量类型详解

    js课程 1-3  Javascript变量类型详解 一.总结 一句话总结:js对象点(属性方法),json对象冒号(属性方法).属性和方法区别只有一个括号. 1.json对象中的函数的使用? 函数名 ...

随机推荐

  1. 【CodeForces】915 F. Imbalance Value of a Tree 并查集

    [题目]F. Imbalance Value of a Tree [题意]给定n个点的带点权树,求所有路径极差的和.n,ai<=10^6 [算法]并查集 [题解]先计算最大值的和,按点权从小到大 ...

  2. LeetCode之数据流中第一个唯一的数字

    使用一个Map维护数字出现的次数,使用一个链表维护只出现一次的数,使用一个变量记录是否找到过终止数字. AC代码: public class Solution { /* * @param : a co ...

  3. tp5 r3 一个简单的SQL语句调试实例

    tp5 r3 一个简单的SQL语句调试实例先看效果核心代码 public function index() { if (IS_AJAX && session("uid&quo ...

  4. SQLite3 安装、基本操作

    1. 安装SQLite3 sudo apt-get install sqlite3 2. 安装Sqlite3编译需要的工具包 如果,你需要的话可以安装该工具包.只是为了体验一把,可以不安装.该项是可选 ...

  5. SQLite3使用详解

    sqlite常量的定义(SQLite3返回值的意思): SQLITE_OK           = 0;  返回成功 SQLITE_ERROR        = 1;  SQL错误或错误的数据库 SQ ...

  6. netif_start_queue/netif_wake_queue/netif_stop_queue

    在网卡驱动中,内核为发送数据包的流量控制提供了几个主要的函数,用来在驱动程序和内核之间传递流控信息. 主要有4个: 1]netif_start_queue  启动接口传输队列 2]netif_wake ...

  7. iTextSharp之pdfRead(两个文件文本内容的比较,指定页数的pdf截取,水印的添加)

    using iTextSharp.text; using iTextSharp.text.pdf; using iTextSharp.text.pdf.parser; using System; us ...

  8. 5、SourceTree使用git

    1.拉取分支 拉去分支请参见:3.SourceTree通过PUTTY连接GitLab 最后内容 注:如果拉取后看不见master,请在gitLab页面的master上新建一个文件即可. 2.创建一个分 ...

  9. shell视频

    本帖最后由 Shell_HAT 于 2014-04-18 16:51 编辑 尚观全套RHCE视频http://pan.baidu.com/s/1pJvzVR1 马哥网络班-中级视频内容http://p ...

  10. logstash参数配置

    input配置: file:读取文件 input { file{ path => ["/var/log/*.log","/var/log/message" ...