1.JavaScript的数据类型

A.原始类型:包含数值、字符串、布尔值、空值(null)和未定义值(undefined)。

Js原始类型均为不可改变类型。对不可变类型调用任何自带方法都不会改变原始值,除非重新赋值。例如:

var s="Hello,World";
s.toUpperCase();//将字串全部大写
console.log("s的值为:"+s);

在Firefox Firebug控制台内执行结果为:

B.对象类型:对象为Js类的实例,使用“构造函数”为Js自带的五个类构造对象。Js自带的5个类为:Array(数组类),Date(时间类),RegExp(正则类),Error(错误类)和函数类(function,有自己的语法)。

以上5类中,除数组类为“名/值”对的有序集合外,其他类均为“名/值”对的无序集合。

构造函数实例:

var date=new Date();//构造一个时间类对象,计算自1970年1月1日到当前时间所经过的毫秒数

2.JavaScript的整数范围

JavaScript仅能识别(-2)53至(2)53之间的整数。

A.数值上溢:

数据超过(2)53时:以Infinity(正无穷)来表示。

数据小于(-2)53时:以-Infinity(负无穷)来表示。

B.数值下溢:

正浮点数无限接近于0,超过Js能表示的精度:以0来表示。

负浮点数无限接近于0,超过Js能表示的精度:以-0来表示。

在JS严格模式下,0与(-0)相等。

3.JavaScript使用二进制浮点数

实数有无穷个,但JavaScript不能表示全部的实数,某些实数只能用二进制浮点数近似表示。

Js可以精确表示:1/2,1/4,1/8...1/1024...等

Js不可以精确表示:1/10,1/100,1/1000...等,在JavaScript的真实运行环境中,0.3-0.2=0.9999999999999998

任何使用二进制浮点数表示的编程语言都存在这个问题。

4.JavaScript特殊数值的计算

除了Infinity(无穷)外,Js中还有对数值的特殊表示方法,如NaN(Not a Number,非数),当一个非数值与数值进行算术运算(+ - * /)时,程序将返回NaN。此外,JavaScript还有一些关于Infinity和0的特殊运算,仅举例如下:

console.log("0*Infinity的值为:"+(0*Infinity)); //返回NaN
console.log("Infinity*Infinity的值为:"+(Infinity*Infinity)); //正无穷相乘,结果仍未Infinity
console.log("Infinity/Infinity的值为:"+(Infinity/Infinity)); //返回NaN
console.log("Infinity/0的值为:"+(Infinity/0)); //正无穷除以0,仍然为正无穷
console.log("Infinity/-0的值为:"+(Infinity/-0)); //正无穷除以-0,为负无穷
console.log("0/0的值为:"+(0/0));//返回NaN
console.log("(-1)/Infinity的值为:"+(-1/Infinity)); //下溢为0

在Firefox Firebug控制台内执行结果为:

5.如何测试用户输入是否为数值

无法用(k==NaN)来判定k本身是否为非数,因为当k为非数时,它与自身不相等。也就是说(k==NaN)将返回false。

应使用isNaN(k)函数,或者是(k!=k)来判定,当k为非数时,(k!=k)将返回true。

可以正常运算的数都可以使用isFinite(k)来检验,k为参数,在表单检验时尤其有用。下文案例为:检验用户在表单上输入的数是否为可以运算的数值

<table>
<tr>
<td>请输入任意数字:</td>
<td><input id="monthly"></input></td>
</tr>
<tr>
<td><button onclick="calculate()">请点击计算</button></td>
</tr>
</table>

以下为检验函数calculate()的代码:

function calculate(){
var a=document.getElementById("monthly").value;
var k=parseFloat(a).toFixed(2);
if(isFinite(k)){
console.log("您输入的为数字!您输入的数字为"+k);
}else{
console.log("您输入的不是数字,请重新输入!您输入的值为"+a);
}
}

1)用户输入一个字符串“dd”:                                                        在Firefox Firebug控制台内执行结果为:

                                  

2)用户输入一个数值:                                                                在Firefox Firebug控制台内执行结果为:

                                 

路冉的JavaScript学习笔记-2015年1月23日的更多相关文章

  1. 路冉的JavaScript学习笔记-2015年2月5日

    1.为Js原始值创建临时对象,并进行属性引用 var s="text"; s.len=4;//这里Js调用new String(s)的方法创建了一个临时对象,用来属性引用 cons ...

  2. 2015年10月23日JS笔记

    ECMAScript标准:JavaScript核心语法 微软:Jscript ECMAScript标准:一纸空文 JavaScript和JScritp都号称完全实现了 ECMAScript标准 W3C ...

  3. 初识Less(2015年05月23日)

    因为最近在研究Bootstrap,然后才了解到Less,听说Less很强大,又听说Bootstrap+Less会更搭,所以就决定也顺带了解下Less的相关知识. come  on...... 一.简介 ...

  4. github使用指南(2015年3月23日更新了本地创建仓库再推送到remote仓库的使用方法)

    我是通过这个来学习的.个人愚笨,琢磨了半天,终于搞通了,醉了醉了,以前一直使用svn,用git确实有点水土不服.本文以如何使用git为主来展开,不涉及太多理论. git是分布式的版本管理.什么叫分布式 ...

  5. Palindrome Number 2015年6月23日

    题目: 判断一个数是不是回文数 Determine whether an integer is a palindrome. Do this without extra space. 思路:借助上一道求 ...

  6. Reverse Integer 2015年6月23日

    题目: Reverse digits of an integer. Example1: x = , return Example2: x = -, return - 思路:递归 解答: / test ...

  7. JavaScript学习笔记[0]

    JavaScript学习笔记[0] 使用的是廖雪峰JavaScript教程. 数据类型 Number 表示数字,不区分浮点整形. === 比较时不转化数据类型. == 反之. NaN与任何值都不想等, ...

  8. Java程序猿的JavaScript学习笔记(汇总文件夹)

    最终完结了,历时半个月. 内容包含: JavaScript面向对象特性分析,JavaScript高手必经之路. jQuery源代码级解析. jQuery EasyUI源代码级解析. Java程序猿的J ...

  9. Java程序猿的JavaScript学习笔记(8——jQuery选择器)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

随机推荐

  1. c++ 学习笔记 c++ 引用C库注意点:#ifdef __cplusplus 倒底是什么意思?

    时常在cpp的代码之中看到这样的代码: #ifdef __cplusplus extern "C" { #endif //一段代码 #ifdef __cplusplus } #en ...

  2. FastJSON学习

    这几天在用FastJSON,发现需要测试一些关键点,包括: 1.是否支持内部类:测试结果是支持,但是需要设置为静态类(static) 2.是否支持继承的自动序列化及反序列化:测试结果是支持 3.缺字段 ...

  3. udelay、mdelay、ndelay、msleep使用比较说明

    时间单位:    毫秒(ms).微秒 (μs).纳秒(ns).皮秒(ps).飞秒(fs).阿秒.渺秒    1 s = 10^3 ms = 10^6 us = 10^9 ns = 10^12 ps = ...

  4. misc_register、 register_chrdev 的区别总结

    参考: http://longer.spaces.eepw.com.cn/articles/article/item/60415 http://imganquan.org/blog/?p=350 网上 ...

  5. ERP 能够做什么

    1. ERP 能解决既有物料短缺又有库存积压的库存管理难题 企业在管理库存问题上,经常处于两难之中. 要多存物料,肯定会积压资金:少存物料,又怕物料短缺,影响生产. 这样,物料的短缺和库存积压总是同时 ...

  6. Oracle系列之表空间

    涉及到表的处理请参看原表结构与数据  Oracle建表插数据等等 创建表空间等等 select tablespace_name from dba_tablespaces;--dba权限用户查询数据库中 ...

  7. Linux Kernel ‘exitcode_proc_write()’函数本地缓冲区溢出漏洞

    漏洞名称: Linux Kernel ‘exitcode_proc_write()’函数本地缓冲区溢出漏洞 CNNVD编号: CNNVD-201311-061 发布时间: 2013-11-07 更新时 ...

  8. [HDU 1520] Anniversary party

    Anniversary party Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others ...

  9. easyui datagrid隔行变色

    属性striped设置为true,即striped:true. 如果想更改颜色,可以更改easyui.css中的.datagrid-row-alt样式.

  10. iOS 开发者计划申请 2014 年最新心得[转]

    iOS 开发者计划申请 2014 年最新心得 http://myfairland.net/ios-developer-program/