1、JavaScript的数据类型分为两类:原始类型和对象类型;

原始类型包括:数字,字符串,布尔值,null和undefined; (都是不可变类型,值不可以修改)

对象类型:普通对象和函数;

函数可使用new新建对象,即构造函数;每个构造函数定义了一类对象--由构造函数初始化的对象组成的集合;

类可以看做是对象类型的子类型,javascript语言定义的类主要有:数组Array,函数Function,日期Date

正则RegExp: var pattern=/s$/ 等价于 var pattern = new RegExp("s$");用于匹配任何以‘s’结束的字符串;

错误Error:定义了表示程序中运行是错误和语法错误的对象; 在try--catch中使用。

--------------------------------------------

关于常用类型判定例子:

定义变量:var n;

赋值-----

获取类型: typeof n

// 'undefined' --- 这个值未定义;
// 'boolean' --- 这个值是布尔值;
// 'string' --- 这个值是字符串;
// 'number' --- 这个值是数值;
// 'object' --- 这个值是对象或null;
// 'function' --- 这个值是函数。

null和函数也是对象,但返回值不同;

---------------------------------------------

2、数值类型:

1)、所有数字均用浮点数值表示;

2)、JavaScript预定义了全局变量NaN非数字值与Infinity正无穷大;

  仅当x为NaN时,x!=x为true,其他都为false;

仅当参数是NaN或非数字值时,isNaN()返回值为true;

仅当参数不是NaN、Infinity或-Infinity的时候,isFinite()返回true;

3)、javascript浮点数表示法是一种二进制表示法,不能精确表示类似0.1这样的数字;

  var x = 0.3- 0.2; var y = 0.2- 0.1;alert(x == y); //false

      javascript真实运行环境中:x=0.099 999 999 999 999 98    y = 0.1;

3、字符串,正则的使用例子:

var text = "test:1,2,3";

var pattern = /\d+/g //匹配所有包含一个或多个数字的实例;

pattern.test(text); //true 匹配成功;

text.search(pattern); //6 首次匹配成功位置;

text.match(pattern);  //[1,2,3]所有匹配成功组成的数组;

text.replace(pattern,'#'); //[test:#,#,#] 替换

4、布尔值:

判断以下值时:undefined,null,0,-0,NaN,"" 都是false;

var y; var x= null; alert(x == y);// true  y是undefined ;

5、类型转换:

1.number-to-string:

var n = 123456.789;

  n.toFixed(2) //123456.78 指定小数点后的位数;

  n.toExponential(2) //1.23e+5 指定指数计数法,小数点钱固定一位;

n.toPrecision(10) //123456.7890   指定有效数字位数

  n.toPrecision(2) //1.23e+5 如小于整数位数,则转为指数

2.string-to-number:

parseInt() //解析整数;

parseFloat() //解析整数和浮点数;

6、函数:函数变量声明提前

var n = 'global';

function(){

  console.log(n);  //undefined

    var n = 'scope';

console.log(n);  //scope     

}

等价于:

var n = 'global';

function(){

    var n;

   console.log(n);  //undefined

    n = 'scope';

console.log(n);  //scope     

}

JavaScript的理解记录(1)的更多相关文章

  1. JavaScript的理解记录(6)

    ---接上篇: 四.CSS相关: 1.CSS不支持注释// 支持注释/* */ 2. 几种浏览器厂商前缀: Firefox : -moz-;    Chrome:-webkit- ;      IE: ...

  2. JavaScript的理解记录(5)

    ---接上篇: 三.DOM解析: 1.Document Object Model(DOM):是表示和操作HTML和XML文档内容的基础API;其中几个重要的类有:Document和Element,Te ...

  3. JavaScript的理解记录(4)

    客户端JavaScript:客户端就是Web浏览器; 一. 前奏: Web文档(document):一些呈现静态信息的页面,虽然有的页面是会动的,但信息本身还是静态! Web应用:可以动态载入信息,相 ...

  4. JavaScript的理解记录(3)

    ---接上篇 一.函数:    1. 函数定义后直接执行:var f = (function(x){ return x*10}(10)); 2. 函数的调用有四种方式: 作为函数:作为方法:作为构造函 ...

  5. JavaScript的理解记录(2)

    一.表达式与运算符: 1.对于属性访问表达式: var arr = {first:"hh","second":"gg",third:null ...

  6. Javascript中理解发布--订阅模式

    Javascript中理解发布--订阅模式 阅读目录 发布订阅模式介绍 如何实现发布--订阅模式? 发布---订阅模式的代码封装 如何取消订阅事件? 全局--发布订阅对象代码封装 理解模块间通信 回到 ...

  7. 第一百二十九节,JavaScript,理解JavaScript库

    JavaScript,理解JavaScript库 学习要点: 1.项目介绍 2.理解JavaScript库 3.创建基础库 从本章,我们来用之前的基础知识来写一个项目,用以巩固之前所学.那么,每个项目 ...

  8. 《javascript个人理解,个人整理。》

    万事开头难. 本人做前端工程师,已几年,没有特别大的,已文字方式去做总结. 前段时间,早已经想好,但是迟迟没有去下笔!好在现在陆陆续续的写下去. 我知道这是一个很大的工程,但是我还是想做下去,不为别的 ...

  9. 【转】Javascript中理解发布--订阅模式

    Javascript中理解发布--订阅模式 阅读目录 发布订阅模式介绍 发布---订阅模式又叫观察者模式,它定义了对象间的一种一对多的关系,让多个观察者对象同时监听某一个主题对象,当一个对象发生改变时 ...

随机推荐

  1. 谁在死锁Mutex——用Windbg查找Mutex死锁所有者线程

    Who is blocking that Mutex? - Fun with WinDbg, CDB and KD 05 Aug 2006 By Ingo Rammer I'm currently t ...

  2. dedecms调用标签总结(一)

    dedecms 基本包含了一个常规网站需要的一切功能,拥有完善的中文学习资料,很容易上手,学习成本较低.学会dedecms 的模板修改.栏目新增.内容模型新增和常用的标签调用方法后,即便我们不懂 ph ...

  3. file_get_contents模仿浏览器头(user_agent)获取数据

    本篇文章是对file_get_contents模仿浏览器头(user_agent)获取数据进行了详细的分析介绍,需要的朋友参考下     什么是user agentUser Agent中文名为用户代理 ...

  4. 2016-2017 CT S03E07: Codeforces Trainings Season 3 Episode 7 - HackerEarth Problems Compilation

    B: 思路: 暴力,每两个判断一下; C: 思路: 容斥定理,先枚举脖子下面那个点和那个不可描述的点,算出所有的方案数,这里面有多的腿当成了脖子或者胳膊的,然后就再枚举这种情况把这些减去,又减多了; ...

  5. USACO GCD Extreme(II)

    题目大意:求gcd(1,2)+gcd(1,3)+gcd(2,3)+...+gcd(n-1,n) ---------------------------------------------------- ...

  6. JSTL基础

    是java中的一个定制标记库集 实现了jsp页面中的代码复用,基于标签库原理,重复率较高的代码块支持复用,提高效率 书写jsp页面时可读性更强 http://archive.apache.org/di ...

  7. ArrayList如何实现线程安全

    一:使用synchronized关键字,这个大家应该都很熟悉了,不解释了: 二:使用Collections.synchronizedList();使用方法如下: 假如你创建的代码如下:List< ...

  8. u3d_Shader_effects笔记2 自定义surfaceDiffuseLight

    1.前面的心情 今晚7点半睡着后,9点半左右被吵醒.醒来后非常失落,感觉人生到底在追求什么,我又在追求什么.昨晚梦到妈妈了.最近不时会想到爷爷的去世.人世的险恶,良心的缺失.不过一切总要向前看,至少我 ...

  9. Android中使用Gson解析JSON数据的两种方法

    Json是一种类似于XML的通用数据交换格式,具有比XML更高的传输效率;本文将介绍两种方法解析JSON数据,需要的朋友可以参考下   Json是一种类似于XML的通用数据交换格式,具有比XML更高的 ...

  10. webstrom快捷键速查

    编辑 Ctrl + Space 基本代码完成 (任何类. 方法或变量名称)Ctrl + Shift + Enter 完整的语句Ctrl + P (在方法调用参数) 内的参数信息Ctrl + Q 快速的 ...