javascript基础拾遗(六)
1.Date内置对象
获取系统时间
var now = new Date()
console.log(now)
console.log(now.getDate())
console.log(now.getDay())
console.log(now.getMilliseconds())
2.构造Date对象
var now = new Date(2017, 12, 6)
console.log(now)
console.log(now.getDate())
console.log(now.getDay())
console.log(now.getMilliseconds())
需要注意的是,javascript的月份为0-11,因此,var now = new Date(2017, 12, 6)的时间为2018-01-06
3.RegExp正则
正则声明的两种方式
var re1 = /ABC\-001/;
var re2 = new RegExp("ABC\\-001")
console.log(re1)
console.log(re2)
示例如下:
var re1 = /^\d{3}-\d{3,8}$/;
console.log(re1.test('010-12345'))
console.log(re1.test('010-1234x'))
console.log(re1.test('010 12345'))
运行结果: true false false
正则表达式的作用如下:
1)切分字符串
固定分隔符切分
'a b c'.split(' ');//['a','b',' ','c']
正则规则切分
'a b c'.split(/\s+/);//['a','b','c']
多个空格或逗号切分
'a,b, c'.split(/[\s,]+/)
2)提取子串
var re1 = /^(\d{3})-(\d{3,8})$/;
console.log(re1.exec('010-12345'))
运行结果:['010-12345','010','12345']
括号()表示要提取的分组
3)贪婪匹配,非贪婪匹配
贪婪匹配匹配尽可能多的字符
var re1 = /^(\d+)(0*)$/;
console.log(re1.exec('102300'))
运行结果:["102300", "102300", ""]
非贪婪匹配匹配尽可能少的字符
var re1 = /^(\d+?)(0*)$/;
console.log(re1.exec('102300'))
运行结果:["102300","1023","00"]
4)全局匹配
var r1 = /test/g;
// 等价于:
var r2 = new RegExp('test', 'g');
示例:
var re1 = /^(\d+?)(0*)$/;
var s = 'JavaScript, VBScript, JScript and ECMAScript';
var re=/[a-zA-Z]+Script/g;
console.log(re.exec(s));
console.log(re.lastIndex);
console.log(re.exec(s));
console.log(re.lastIndex);
运行结果:
[JavaScript]
10
[VBScript]
20
全局匹配类似搜索,不能使用/^...$/
正则表达式i,表示忽略大小写,m,表示执行多行匹配
4.JSON对象
JSON是一种数据交换格式
1)可以包含以下几种数据类型:
number:数值
boolean:true/false
string:字符串
null:空对象
array:数组
object:对象{}
示例如下:
var language = {
name: 'javascript',
score: 9.0,
popular:true
}
console.log(language)
var s = JSON.stringify(language)
console.log(s)
运行结果:
{name: "javascript", score: 9, popular: true}
{"name":"javascript","score":9,"popular":true}
2)JSON序列化
JSON.stringify(json_obj, null, ' ');
将JSON对象序列化成JSON格式字符串
第一个参数:要序列化的对象
第二个参数:要输出的属性,或者属性处理函数
如['name'],那么只会输出name属性
或者函数,将string类型的value转大写
JSON.stringify(json_obj, convert, ' ');
function convert(key, value) {
if (typeof value === 'string') {
return value.toUpperCase();
}
return value;
}
第三个参数:属性前添加空格,可以使输出更美观
也可以自定义序列化方法
var language = {
name: 'javascript',
score: 9.0,
popular:true,
toJSON: function(){
return {
'Name': this.age,
'Score': this.score
}
}
}
console.log(language)
var s = JSON.stringify(language)
console.log(s)
3)JSON反序列化
将JSON格式字符串,转化为一个JavaScript对象
JSON.parse('{"name":"小明","age":14}'); // Object {name: '小明', age: 14}
javascript基础拾遗(六)的更多相关文章
- 回归JavaScript基础(六)
主题:引用类型Date.RegExp的介绍. 上节主要主要介绍了Object.Array引用类型.这节将继续为大家介绍引用类型,并对书中的一些知识点进行总结与归纳,也借此巩固自己对JavaScript ...
- JavaScript基础学习(六)—函数
一.函数的定义 1.function语句形式 //1.function语句式 function test1(){ alert("I am test1"); } test1(); 2 ...
- javascript基础拾遗(十三)
1.jQuery的特点 jQuery是目前非常流行的javascript库,理念是"Write Less,Do More" 1)消除浏览器差异 2)简洁的操作DOM方法 3)轻松实 ...
- javascript基础拾遗(十二)
1.javascript的单线程特性 在javascript中,所有的代码都是单线程的 因此所有的网络操作,浏览器事件,都必须是异步执行的,异步执行的逻辑是回调. function callback( ...
- javascript基础拾遗(十一)
1.DOM操作 1)查找 //根据id查找 document.getElementById() //根据html标签查找 documnet.getElementByTagName() //根据样式cl ...
- javascript基础拾遗(十)
1.支持ES6标准的浏览器 IE10+ Chrome Safari Firefox 移动端浏览器统一都支持 需要注意的是,不同浏览器对各个特性的支持也不一样 2.window对象 当前浏览器窗口对象 ...
- javascript基础拾遗(七)
1.对象的继承__proto__ var Language = { name: 'program', score: 8.0, popular: function () { return this.sc ...
- javascript基础拾遗(五)
1.什么是箭头函数 ES6引入的一种新的函数,类似匿名函数,x=>xx 箭头左端为函数参数,右端为函数体 相当于 function (x){ retutn xx } 2.箭头函数的特点 更简洁 ...
- javascript基础拾遗(二)
1.对象定义 定义属性 var language = { name:'javascript', score:9.0 }; console.log(language.name) console.log( ...
随机推荐
- Android 蓝牙通信——AndroidBluetoothManager
转载请说明出处! 作者:kqw攻城狮 出处:个人站 | CSDN To get a Git project into your build: Step 1. Add the JitPack repos ...
- windows常用命令行整理
Windows虽然以GUI界面为主,但有时命令行也起到了很大的作用,下面就介绍几个常用.常见的windows命令行命令 1.ping 功能:用来测试数据包能否通过IP协议到达特定主机.即测试本机与特定 ...
- Android Intent之Action应用
Log.i("txrjsms", "whereDoYouJumpFrom:"+getIntent().getPackage()); 结果是null Log.i( ...
- mysql之limit m,n
limit是mysql的语法 select * from table limit [m],n; 其中,m—— [m]为可选,如果填写表示skip步长,即跳过m条. n——显示条数.指从第m+1条记录开 ...
- Comparable 与 Comparator
Comparable & Comparator 都是用来实现集合中元素的比较.排序的,只是 Comparable 是在集合内部定义的方法实现的排序,Comparator 是在集合外部实现的排序 ...
- Word2Vec中文语料实战
http://blog.csdn.net/gnehcuoz/article/details/52136371
- vim 可视化模式(visual模式)
转文章 为了便于选取文本,VIM 引入了可视(Visual)模式. 要选取一段文本,首先将光标移到段首,在普通模式下按 v 进入可视模式,然后把光标移到段末. 需要注意,光标所在字符是包含在选区中的 ...
- SPI、I2C、UART三种串行总线协议的区别和SPI接口介绍(转)
SPI.I2C.UART三种串行总线协议的区别 第一个区别当然是名字: SPI(Serial Peripheral Interface:串行外设接口); I2C(INTER IC BUS) UART( ...
- HDU 3018 Ant Trip (欧拉回路)
Ant Trip Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Su ...
- 六款值得推荐的Android开源框架简介
技术不再多,知道一些常用的.不错的就够了.下面就是最近整理的“性价比”比较高的Android开源框架,应该是相对实用的. 1.volley 项目地址 https://github.com/smanik ...