一:总体的类型系

基本类型:数字类型(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. JAVA多线程基础学习二:synchronized

    本篇主要介绍Java多线程中的同步,也就是如何在Java语言中写出线程安全的程序,如何在Java语言中解决非线程安全的相关问题,没错就是使用synchronized. 一.如何解决线程安全问题? 一般 ...

  2. HttpClient 模拟登陆知乎

    最近做爬虫相关工作,我们平时用HttpWebRequest 比较多,每一个Url都要创建一个HttpWebRequest实例, 而且有些网站验证比较复杂,在登陆及后续抓取数据的时候,每次请求需要把上次 ...

  3. Problem 2278 YYS (FZU + java大数)

    题目链接:http://acm.fzu.edu.cn/problem.php?pid=2278 题目: 题意: 有n种卡牌,每种卡牌被抽到的概率为1/n,求收齐所有卡牌的天数的期望. 思路: 易推得公 ...

  4. Python面向对象学习 1 (什么是面向对象,面向对象的应用场景,待更新)

    程序设计的三种基本结构: 面向对象,面向过程,函数式编程   1,什么是面向对象编程    面向对象编程是一种编程方式,此编程方式的落地需要使用 “类” 和 “对象” 来实现,所以,面向对象编程其实就 ...

  5. 解决Chrome下表单自动填充后背景色为黄色

    Chrome浏览器在表单自动填充后会显示黄色背景,这是Chrome的私有属性导致,对于有洁癖的人来讲,是不喜欢的,我们可以手动去掉. 代码如下: input:-webkit-autofill { -w ...

  6. XGBoost与LightGBM对比分析(转)

    尊重原创 来源: https://blog.csdn.net/a790209714/article/details/78086867   XGBoost的四大改进: ①改进残差函数 不用Gini作为残 ...

  7. flask插件系列之flask_cors跨域请求

    前后端分离在开发调试阶段本地的flask测试服务器需要允许跨域访问,简单解决办法有二: 使用flask_cors包 安装 pip install flask_cors 初始化的时候加载配置,这样就可以 ...

  8. 72.xilinx vivado zynq vdma仿真及应用详解(一)

    很多人用zynq平台做视频图像开发,但是对vdma了解比较少,上手起来稍微有些困难,我针对这一现象,做了一个基于vivado和modelsim的仿真和应用测试工程,并写篇文章做些介绍,希望能对大家有帮 ...

  9. MySQL数据库的“十宗罪”【转】

    今天就给大家列举 MySQL 数据库中最经典的十大错误案例,并附有处理问题的解决思路和方法.希望能给刚入行或数据库爱好者一些帮助,今后再遇到任何报错,我们都可以很淡定地去处理.学习任何一门技术的同时, ...

  10. mysql开启GTID跳过错误的方法【转】

    1.数据库版本 MySQL> select version()    -> ;+-------------------------------------------+| version( ...