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. cocos之观察者模式应用实例

    观察位置: 定义宏常量位置: 添加观察者回调函数位置: 回调函数实现位置:

  2. 关于oracle数据库报12505错误的问题!

    问题阐述: 导致oracle报12505错误的原因比较多,但是最可能一种原因就是客户端的监听出了问题. 解决办法: 在oracle安装目录下找到listener.ora 和 tnsnames.ora, ...

  3. linux监控命令nc用法

    一.nc命令检测端口的用法 # nc -v -w 10 %IP% -z %PORT% -v 显示指令执行过程. -w <超时秒数> 设置等待连线的时间. -u 表示使用UDP协议 -z 使 ...

  4. KVM 介绍(2):CPU 和内存虚拟化

    学习 KVM 的系列文章: (1)介绍和安装 (2)CPU 和 内存虚拟化 (3)I/O QEMU 全虚拟化和准虚拟化(Para-virtulizaiton) (4)I/O PCI/PCIe设备直接分 ...

  5. 百度CDN 网站SSL 配置

    百度CDN SSL配置步骤 一般从SSL提供商购买到的证书是CRT二进制格式的. 1. 将 CRT 导入到IIS中, 然后从IIS中导出为PFX格式 2. 下载openssl,执行下面命令 提取用户证 ...

  6. 如何通过JQuery将DIV的滚动条滚动到指定的位置

    这里有一个方法可以将DIV的滚动条滚动到其子元素所在的位置,方便自动定位. var container = $('div'), inner = $('#inner'); container.scrol ...

  7. 【转载】SweetAlert2 使用

    SweetAlert2是一款功能强大的纯Js模态消息对话框插件.SweetAlert2用于替代浏览器默认的弹出对话框,它提供各种参数和方法,支持嵌入图片,背景,HTML标签等,并提供5种内置的情景类, ...

  8. AC日记——计算2的N次方 openjudge 1.6 12

    12:计算2的N次方 总时间限制:  1000ms 内存限制:  65536kB 描述 任意给定一个正整数N(N<=100),计算2的n次方的值. 输入 输入一个正整数N. 输出 输出2的N次方 ...

  9. c++ 基于wincrypt的DES CBC模式加解密

    des.h #pragma once #include <windows.h> #include <atlstr.h> #include <wincrypt.h> ...

  10. od破解实例

    百度经验: http://jingyan.baidu.com/article/636f38bb4091e4d6b84610a8.html pc6 http://www.pc6.com/edu/6278 ...