JavaScript的类型体系
一:总体的类型系
基本类型:数字类型(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的类型体系的更多相关文章
- JavaScript事件类型
JavaScript事件类型 Web浏览器中可能发生的事件有很多类型.这里我将主要将下面几种常用的事件类型: UI事件 焦点事件 鼠标与滚轮事件 键盘与文本事件 复合事件 变动事件 HTML5事件 设 ...
- Flow: JavaScript静态类型检查工具
Flow: JavaScript静态类型检查工具 Flow是Facebook出品的,针对JavaScript的静态类型检查工具.其代码托管在github之上,并遵守BSD开源协议. 关于Flow 它可 ...
- javascript 操作符类型隐性转换
javascript 操作符类型隐性转换 (一).一元操作符只能操作一个值的操作符叫做一元操作符1.递增和递减操作符a. 在应用于一个包含有效数字字符的字符串时,先将其转换为数字值,再执行加减1的操作 ...
- javascript学习-类型判断
javascript学习-类型判断 1.类型判断的的武器 javascript中用于类型判断的武器基本上有以下几种: 严格相等===,用来判断null,undefined,true,false这种有限 ...
- JavaScript的类型自动转换高级玩法JSFuck
0 前言 最开始是不小心在微信公众号(程序员大咖)看到一篇JS的高逼格代码,然后通过里面的链接跳转到了JSFuck的wiki,就像顺着迷宫找宝藏的感觉,感叹JS的自动类型转换的牛逼. 1 样例 (!( ...
- 面向对象的JavaScript --- 动态类型语言
面向对象的JavaScript --- 动态类型语言 动态类型语言与面向接口编程 JavaScript 没有提供传统面向对象语言中的类式继承,而是通过原型委托的方式来实现对象与对象之间的继承. Jav ...
- javascript 字典类型的使用
javascript 字典类型的使用 1.使用Array: var arr = new Array(); arr["zs"] = "zhangsan"; ar ...
- javascript变量类型及作用域
javascript变量类型及作用域 一.简介 变量类型 ECMAScript变量可能包含两种不同类型的数据值:基本类型和引用类型. 基本类型 基本类型指的是简单的数据段,5种基本数据类型:undef ...
- js课程 1-3 Javascript变量类型详解
js课程 1-3 Javascript变量类型详解 一.总结 一句话总结:js对象点(属性方法),json对象冒号(属性方法).属性和方法区别只有一个括号. 1.json对象中的函数的使用? 函数名 ...
随机推荐
- JAVA多线程基础学习二:synchronized
本篇主要介绍Java多线程中的同步,也就是如何在Java语言中写出线程安全的程序,如何在Java语言中解决非线程安全的相关问题,没错就是使用synchronized. 一.如何解决线程安全问题? 一般 ...
- HttpClient 模拟登陆知乎
最近做爬虫相关工作,我们平时用HttpWebRequest 比较多,每一个Url都要创建一个HttpWebRequest实例, 而且有些网站验证比较复杂,在登陆及后续抓取数据的时候,每次请求需要把上次 ...
- Problem 2278 YYS (FZU + java大数)
题目链接:http://acm.fzu.edu.cn/problem.php?pid=2278 题目: 题意: 有n种卡牌,每种卡牌被抽到的概率为1/n,求收齐所有卡牌的天数的期望. 思路: 易推得公 ...
- Python面向对象学习 1 (什么是面向对象,面向对象的应用场景,待更新)
程序设计的三种基本结构: 面向对象,面向过程,函数式编程 1,什么是面向对象编程 面向对象编程是一种编程方式,此编程方式的落地需要使用 “类” 和 “对象” 来实现,所以,面向对象编程其实就 ...
- 解决Chrome下表单自动填充后背景色为黄色
Chrome浏览器在表单自动填充后会显示黄色背景,这是Chrome的私有属性导致,对于有洁癖的人来讲,是不喜欢的,我们可以手动去掉. 代码如下: input:-webkit-autofill { -w ...
- XGBoost与LightGBM对比分析(转)
尊重原创 来源: https://blog.csdn.net/a790209714/article/details/78086867 XGBoost的四大改进: ①改进残差函数 不用Gini作为残 ...
- flask插件系列之flask_cors跨域请求
前后端分离在开发调试阶段本地的flask测试服务器需要允许跨域访问,简单解决办法有二: 使用flask_cors包 安装 pip install flask_cors 初始化的时候加载配置,这样就可以 ...
- 72.xilinx vivado zynq vdma仿真及应用详解(一)
很多人用zynq平台做视频图像开发,但是对vdma了解比较少,上手起来稍微有些困难,我针对这一现象,做了一个基于vivado和modelsim的仿真和应用测试工程,并写篇文章做些介绍,希望能对大家有帮 ...
- MySQL数据库的“十宗罪”【转】
今天就给大家列举 MySQL 数据库中最经典的十大错误案例,并附有处理问题的解决思路和方法.希望能给刚入行或数据库爱好者一些帮助,今后再遇到任何报错,我们都可以很淡定地去处理.学习任何一门技术的同时, ...
- mysql开启GTID跳过错误的方法【转】
1.数据库版本 MySQL> select version() -> ;+-------------------------------------------+| version( ...