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. 判断数据库表字段是否为null值,采用is null

    use UserCentergo select * from AccountDetails1.判断一个字段是否为null值,进行查询:update AccountDetails set Project ...

  2. ASP.NET UpdatePanel实现点击按钮无刷新且执行js脚本

    [一篮饭特稀原创,转载请注明出自http://www.cnblogs.com/wanghafan/p/3770779.html]  *.aspx: <asp:ScriptManager ID=& ...

  3. javaweb学习总结(三十四)——使用JDBC处理MySQL大数据

    一.基本概念 大数据也称之为LOB(Large Objects),LOB又分为:clob和blob,clob用于存储大文本,blob用于存储二进制数据,例如图像.声音.二进制文等. 在实际开发中,有时 ...

  4. 未来 USB Type-C 将可靠软体判断线材是否符合规定

    USB Type-C 插头允许通过的电流和功率比过去常见的 USB 规范要大得多,因此从市面上「随便买一条」USB Type-C 的充电线的危险也同样大得多,毕竟不是所有的线材能承受的电流都一样,万一 ...

  5. 延时过程中要加上app.processEvents(),进度条里也要加上这句

    如何让程序等待一段时间QTime t;t.start();while(t.elapsed()<1000);这种死循环也是一种常见错误用法.但改成正确的还是比较简单的: QTime t;t.sta ...

  6. 《ArcGIS Engine+C#实例开发教程》第一讲桌面GIS应用程序框架的建立

    原文:<ArcGIS Engine+C#实例开发教程>第一讲桌面GIS应用程序框架的建立 摘要:本讲主要是使用MapControl.PageLayoutControl.ToolbarCon ...

  7. Android 圆角Button

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAbEAAADrCAYAAADnsqiUAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAA

  8. Linux伙伴系统1

    (一)--伙伴系统的概述 Linux内核内存管理的一项重要工作就是如何在频繁申请释放内存的情况下,避免碎片的产生.Linux采用伙伴系统解决外部碎片的问题,采用slab解决内部碎片的问题,在这里我们先 ...

  9. wzplayer for ios 针对(mms)优化版本V1.0

    wzplayer for ios针对mms优化版本发布. 1.支持mms,http,rtmp,rtsp等协议 2.支持全格式 下载地址:http://www.coolradio.cn/WzPlayer ...

  10. Emeditor所有快捷键操作

    新建文本    Ctrl+N         创建一个新的文本文件. 打开         Ctrl+O    打开一个已存在的文件. 保存         Ctrl+S     保存当前文件. 重新 ...