js中怎么把日期转换成数字?

JavaScript022

js中怎么把日期转换成数字?,第1张

方法主要有二种:转换函数、强制类型转换。

具体步骤:

一、转换函数:js提供了parseInt()和parseFloat()两个转换函数。前者把值转换成整数,后者把值转换成浮点数。仅仅有对String类型调用这些方法,这两个函数才干正确执行;对其它类型返回的都是NaN(NotaNumber)。

一些示比例如以下:

复制代码 代码例如以下:

parseInt("1234blue")//returns1234。

parseInt("0xA")//returns10。

parseInt("22.5")//returns22。

parseInt("blue")//returnsNaN。

parseInt()方法还有基模式,能够把二进制、八进制、十六进制或其它不论什么进制的字符串转换成整数。基是由parseInt()方法的第二个参数指定的,示比例如以下:

复制代码 代码例如以下:

parseInt("AF",16)//returns175。

parseInt("10",2)//returns2。

parseInt("10",8)//returns8。

parseInt("10",10)//returns10。

假设十进制数包括前导0,那么最好采用基数10,这样才不会意外地得到八进制的值比如:

复制代码 代码例如以下:

parseInt("010")//returns8。

parseInt("010",8)//returns8。

parseInt("010",10)//returns10。

parseFloat()方法与parseInt()方法的处理方式相似。

使用parseFloat()方法的还有一不同之处在于,字符串必须以十进制形式表示浮点数,parseFloat()没有基模式。

以下是使用parseFloat()方法的演示样例:

复制代码 代码例如以下:

parseFloat("1234blue")//returns1234.0。

parseFloat("0xA")//returnsNaN。

parseFloat("22.5")//returns22.5。

parseFloat("22.34.5")//returns22.34。

parseFloat("0908")//returns908。

parseFloat("blue")//returnsNaN。

2.强制类型转换

还可使用强制类型转换(typecasting)处理转换值的类型。使用强制类型转换能够访问特定的值,即使它是还有一种类型的。

ECMAScript中可用的3种强制类型转换例如以下:

Boolean(value)——把给定的值转换成Boolean型。

Number(value)——把给定的值转换成数字(能够是整数或浮点数)。

String(value)——把给定的值转换成字符串。

用这三个函数之中的一个转换值,将创建一个新值,存放由原始值直接转换成的值。这会造成意想不到的后果。

当要转换的值是至少有一个字符的字符串、非0数字或对象(下一节将讨论这一点)时,Boolean()函数将返回true。假设该值是空字符串、数字0、undefined或null,它将返回false。

能够用以下的代码段测试Boolean型的强制类型转换。

复制代码 代码例如以下:

Boolean("")//false_emptystring。

Boolean("hi")//true_non-emptystring。

Boolean(100)//true_non-zeronumber。

Boolean(null)//false-null。

Boolean(0)//false-zero。

Boolean(newObject())//true_object。

Number()的强制类型转换与parseInt()和parseFloat()方法的处理方式相似,仅仅是它转换的是整个值,而不是部分值。示比例如以下:

复制代码 代码例如以下:

用法结果

Number(false)0。

Number(true)1。

Number(undefined)NaN。

Number(null)0。

Number("5.5")5.5。

Number("5.6.7")NaN。

Number(newObject())NaN。

Number(100)100。

在后台部署定时任务吧,前台计时器不实际:

页面刷新意味着重新计时(计时器被重置)

没有人会在一个页面停留那么长时间(2小时)

用计时器显得有点……,当然了,一定要前台使用JQuery的话,部署一个函数来计算就好:

加载的时候读取数值基数,然后根据当前时间直接计算出最终变动的值,最后显示即可。

最好的做法还是后台处理,前台请求的数据就是变动后的数值(不管是谁,何时请求?结果都是一样的)。

Date 对象

启用基本存储器并取得日期和时间。

dateObj = new Date()

dateObj = new Date(dateVal)

dateObj = new Date(year, month, date[, hours[, minutes[, seconds[,ms]]]])

参数

dateObj

必选项。要赋值为 Date 对象的变量名。

dateVal

必选项。如果是数字值,dateVal 表示指定日期与 1970 年 1 月 1 日午夜间全球标准时间 的毫秒数。如果是字符串,则 dateVal 按照 parse 方法中的规则进行解析。dateVal 参数也可以是从某些 ActiveX(R) 对象返回的 VT_DATE 值。

year

必选项。完整的年份,比如,1976(而不是 76)。

month

必选项。表示的月份,是从 0 到 11 之间的整数( 1 月至 12 月)。

date

必选项。表示日期,是从 1 到 31 之间的整数。

hours

可选项。 如果提供了 minutes 则必须给出。表示小时,是从 0 到 23 的整数(午夜到 11pm)。

minutes

可选项。 如果提供了 seconds 则必须给出。表示分钟,是从 0 到 59 的整数。

seconds

可选项。 如果提供了 milliseconds 则必须给出。表示秒钟,是从 0 到 59 的整数。

ms

可选项。 表示毫秒,是从 0 到 999 的整数。

说明

Date 对象保存以毫秒为单位表示特定时间段。如果某个参数的值大于其范围或为负数,则存储的其他值将做相应的调整。例如,如果指定 150 秒,JScript 将该数字重新定义为 2 分 30 秒。

如果数字为 NaN,则表示该对象不代表特定的时间段。如果未向 Date 对象传递参数,它将被初始化为当前时间 (UTC)。在能够使用该对象前必须为其赋值。

Date 对象能够表示的日期范围约等于 1970 年 1 月 1 日前后各 285,616 年。

Date 对象具有两个不创建 Date 对象就可以调用的静态方法。它们是 parse 和 UTC。

错误

下面的示例演示了 Date 对象的用法。

function DateDemo(){

var d, s = "Today's date is: " // 声明变量。

d = new Date() // 创建 Date 对象。

s += (d.getMonth() + 1) + "/" // 获取月份。

s += d.getDate() + "/" // 获取日。

s += d.getYear()// 获取年份。

return(s) // 返回日期。

}