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. 工作中常用的Linux命令:ipcs/ipcrm命令

    本文链接:http://www.cnblogs.com/MartinChentf/p/6057100.html (转载请注明出处) ipcs 1. 命令格式 ipcs [resource-option ...

  2. 通过SecureCRT访问亚马逊Amazon EC2主机

    亚马逊推出了免费的云主机服务器 Amazon EC2,它是通过安全密钥来访问主机的. 问题是下载的密钥在SecureCRT 上无法直接使用,需要转换. 下面的方法可以在自己的linux主机上生成sec ...

  3. jQuery UI常用插件使用

    一.什么是插件 ①是遵循一定接口规范编写的程序 ②是原有系统平台功能的扩展和补充 ③只能运行在规定的系统平台下,而不能单独运行 注:由于jQuery插件是基于jQuery脚本库的扩展,所以所有jQue ...

  4. Sass关于颜色函数的乐趣

    阅读目录 1. 了解RGB和HSL颜色标准 2. RGB函数 3. HSL函数 4. Opacity函数 5. 其他颜色函数 6. 一个简单的应用 在Sass中,定义了很多现成的函数,可供我们使用.在 ...

  5. ApplicationWindow

    本文介绍了一个使用ApplicationWindow 和Action 实现的一个文本编辑器.界面美观,基本功能齐全.代码齐全. 首先看 MainWindow.java. //MainWindow.ja ...

  6. C与CPP 在线手册查找

    1. MSDN 的标准与使用 https://msdn.microsoft.com/zh-cn/library/3bstk3k5.aspx 2. Cpp在线查看. http://www.cpluspl ...

  7. 程序Bug---易错点

    只有当图像与HTML文档在同一目录时,才能用相对地址显示.

  8. header

    本文分享几个php header函数的例子,有需要的朋友参考学习下. 转自:http://www.jbxue.com/article/php_header_x5hV63c.html 1,可以使用hed ...

  9. LOG4NET日志配置及使用

    Log4net的安装 Install-Package log4net 1.先弄个日志记录的类 /// <summary> /// 使用LOG4NET记录日志的功能,在WEB.CONFIG里 ...

  10. Swagger 增加 DocumentFilter 隐藏不需要显示的接口

    services.ConfigureSwaggerGen(options => { options.SingleApiVersion(new Info { Version = "v1& ...