js高级程序设计第三版小记

2019-12-19:第五章:引用类型(日期与正则表达式)

2019-12-19  本文已影响0人  Lau17

3.Date类型

ECMAScript中的Date类型来源于Java早期的util.Date类。因此js的日期也是根据从UTC时间1970年1月1日零时开始经过的毫秒数来保存的。

创建日期类型的方法是 var time = new Date()。在不传递任何参数的情况下,Date()构造函数自动为新创建的对象赋值为当前时间。如果想获得特定的日期,那么就必须输入一个时间戳。这个时间戳代表了从UTC时间1970年1月1日零时到目标时间的毫秒数

为了计算这个时间戳,可以使用Date.parse()和Date.UTC()。

Date.parse()方法是输入一个代表时间的字符串,方法将返回代表该日期的时间戳。但是这个字符串的格式并没有明确的定义,其格式是根据PC地区设置而异的:

当pc的地区设置为美国时 当地区为中国时,常规格式是有效的

Date.UTC()方法输入的是若干个参数:年,月(0-11),日(1-31),小时(0-23),分钟(0-60),秒(0-60),在这些参数中,只有年月是必填,其他参数如果没有填写,则全部默认为0。

只填了年月日

另外还可以使用Date.now()来计算调用本函数时当前时间的毫秒数,通常用来在需要统计时间花销或系统性能时,计算初始与结束两次调用Date.now()的时间差。

等待1000毫秒,运行11毫秒

注意这里填写的时间都是基于本地时间来计算的,实际在转换时会首先减去或加上本地时区,达到与UTC时区的同步,再进行下一步计算。

3.1继承方法

Date类型重写了三类最基本的方法:

toLocaleString()返回按照浏览器设置的地区相适应的格式的日期和时间,通常会带有AM或PM。

toString()返回带有时区信息的日期。

二者不同

但是这两个方法在不同的浏览器采用不同地区设置时,返回结果几乎天差地别,因此没什么实际使用价值就是了。

而valueOf()则仍然是返回毫秒数,与上述的几种方法是比较类似的。

3.2日期格式化与日期组件

日期向字符串转换的方法 日期组件

4.RegExp正则表达式

js中的正则使用 / pattern / flag的形式,其中pattern为正则表达式内容,flags为标志,用来声明正则的行为。

三者可以在一个正则表达式里同时出现。

在正则表达式的内容中,对一切元字符必须做转义:通常的元字符包括:\( , \[, \{, \^, \|, \$, \?, \*, \+, \., \], \}, \/,如下例子:

/[ 和 [ 在正则里完全不同

创建正则表达式有两种方式:

① var exp = /[bc]at/g    //字面量法

② var exp = new RegExp(“[bc]at”,“g”)   //构造函数法  

4.1RegExp实例属性

g,对应的属性叫做exp.global(全局,应用于所有字符串,而不会在找到第一个匹配后停止)

i,对应的属性叫做exp.ignoreCase(不区分大小写,匹配时忽略大小写的问题)

m,对应的属性叫做exp.multiline(多行,在一行文本的末尾后还会继续查找下一行是否存在匹配)

lastIndex属性,表示开始搜索下一个匹配项的字符位置,从0开始。

展示last属性

source属性,就是正则具体写的内容,是一个字符串。在上图的例子里就是a.source = "[bc]at"。

4.2RegExp实例方法

① exec()。exec接受一个参数,即要被应用正则的字符串。然后返回第一个匹配项信息的数组。在没有正确匹配值时返回null。

exec()的返回值数组可以访问所有符合匹配原则的字符串,input属性返回被应用的正则字符串本体,index属性返回第一个匹配项在字符串中的位置。

如图所示

② test()。接受一个字符串参数,在完成匹配的情况下返回true,否则返回false。常常用来做条件处理,代表某个字符串里面是否包含某个匹配项,例如检验用户的输入与规则是否相符。

4.3正则表达式的写法

太多了实在,一点一点学实在力不从心,这玩意就现用现学吧,而且网上有N多有用的轮子,随便搬运几个自己在工程里经常使用的:

① /^abc/ 以给定字符开头 

② /zfg$/  以给定字符结尾

③ /[^abc$]/ 表示精确匹配

④ /^1[3458]\d{9}$/ 匹配手机号

⑤ /^(0\d{2}[\-]\d{8})|(0\d{3}[\-]\d{7})$/ 匹配固定电话

⑥ /^[\w\-\.]+\@[\w]+\.[\w]{2,4}$/ 匹配邮箱

⑦ /[^\d]/ 只能输入数字

⑧ /[^\u4E00-\u9FA5]/ 只能输入汉字

⑨ \\< *[img][^\\>]*[src] *= *[\\"\\']{0,1}([^\\"\\'\\ >]*) 提取网页图片

⑩ ((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)) IP地址


上一篇下一篇

猜你喜欢

热点阅读