2018-03-11 上课摘要

今天的课主要讲了callback与正则表达式。

callback

callback:主要是callback hell的历史问题与callback hell的解决方案

error-first:node异步回调规范,将error参数作为第一位。

// error-first 函数
(err, value) => {

}

util.callbackify:接收一个async函数(或者接收返回一个Promise对象那个的函数),并返回一个遵循error-first回调风格的函数。

const util = require('util');
// async function:
async function fn() {
  return 'hello world!';
}
const callback = util.callbackify(fn);

callback((err, ret) => {
  if(err) throw err;
  console.log(ret);
})

// Promise function:
function fn() {
  return Promise.reject(null);
}

const callback = util.callbackify(fn);

callback((err, ret) => {
  err && err.hasOwnProperty('reason') && err.reason === null;
})

生成器generator function,符合可迭代协议迭代器协议

// function* 生成器函数
function* gen() {
  yield 1;
  yield 2;
  yield 3;
}

let g = gen();

// 返回一个yield表达式生成的值
Generator.prototype.next()
// 返回给定值,并结束生成器
Generator.prototype.return()
// 向生成器抛出一个错误
Generator.prototype.throw()

// 常用方法
g.next().value; // 当前yield的值
g.next().done; // 迭代器是否结束

es6新标准Promise + async/await

function resolveAfter2000ms() {
  return new Promise((resolve, reject) => {
    setTimetout(() => { resolve('1') }, 2000)
  })
}

async function asyncCall() {
  console.log('calling asyncCall: ');
  // 执行asyncCall函数,会返回resolveAfter2000ms函数的值。
  // 但是在asyncCall函数中执行的resolveAfter2000ms函数,则会返回resolve的值。
  var result = await resolveAfter2000ms();
  console.log(result);
}

promisify: 接收一个error-first格式的函数,并返回一个Promise格式的对象。

const util = require('util');
const fs = require('fs');

// fs.stat满足最后一个参数是callback并且满足first-error的函数
const stat = util.promisify(fs.stat);

// promise风格
stat('.').then((stats) => {
  // do something
}).catch((err) => {
  // alert error
})

// async/await风格
async function callStat() {
  var stats = await stat('.');
  console.log(stats);
}

关于 管道 & Stream
其实这部分并没有完全吃透,看的内容也主要是解耦KISS拼装。主要是为了程序的灵活和模拟日常生活中的零件化。说白了就是跟插座一样,你一开始插的风筒,后面拔了插电热水壶,完全是不受影响,可以正常使用的。


正则表达式

关于 正则表达式
主要讲了历史以及匹配字符的用法。

元字符
.:匹配 除换行符 以外的 任意字符
\w:匹配 字母数字下划线
\W:匹配不是 字母数字下划线 的字符。
\d:匹配 数字,相当于 [0-9]
\D:匹配 非数字 的字符。
\s:匹配任意 不可见字符,包括 空格制表符换行符 等。
\S:匹配任意 可见字符
^:匹配字符串的 开始位置
$:匹配字符串的 结束位置

量词
*:重复 任意次,相当于 {0,}
?:重复 0次1次,相当于 {0,1}
+:重复 1次更多次,相当于 {1,}
{n}:重复 n次
{n,}:重复 n次 或者 大于n次
{n,m}:重复 n 到 m 次

分支 & 字符集
分支(a|b|c)
字符集:符号为 [abc] === [a-c][^abc] === [^a-c]

分组 & 引用
分组:符号为 ()
分组例子/(\d{4})-(\d{2})-(\d{2})/,一共3个括号,分了三组。

/(\d{4})-(\d{2})-(\d{2})/.match('2018-03-12');
// 会得到1个完整的匹配和3个分组。
// '2018-03-12'  =>   完整的匹配
// '2018'        =>   第一个分组
// '03'          =>   第二个分组
// '12'          =>   第三个分组

引用:默认为 \+数字,比如 \1 or \2 or \3
引用例子/(\d{4})-(\d{2})-\2/,一共2个括号,1个引用,这里要注意,引用第2个,就必须匹配跟第2个引用一模一样的值。

/(\d{4})-(\d{2})-\2/.match('2018-03-03');
=> true

/(\d{4})-(\d{2})-\2/.match('2018-03-04');
/(\d{4})-(\d{2})-\2/.match('2018-03-02');
/(\d{4})-(\d{2})-\2/.match('2018-03-11');
/(\d{4})-(\d{2})-\2/.match('2018-03-12');
=> false

零宽断言环视lookaround assertions
可在当前位置 向前 或者 向后 匹配,并且 不占字符串宽度 的正则匹配。

正向匹配→ 逆向匹配 ←
肯定 (?=pattern) (?<=pattern)
否定 (?!pattern) (?<!pattern)
/ab(?=c)d/.test('abcde');
=> false
// 注释:
// 如果lookaround assertions是占用宽度,那test函数返回的肯定是true。
// 但是这里返回的是false,说明ab(c)d中并不能匹配字符串的abcde,所以它是不占用宽度的。

惰性模式 & 贪婪模式:

贪婪模式 惰性模式
尽可能多的去匹配 尽可能少的去匹配
默认 加个问号
.*, .+, .? .*?,.+?,.??

修饰符 & 标志:

修饰符 全名 意义
g global 全局搜索
i ignoreCase 不区分大小写
m multiline 多行搜索
y sticky “粘性”搜索

编不下去了…完。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,544评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,430评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,764评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,193评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,216评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,182评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,063评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,917评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,329评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,543评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,722评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,425评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,019评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,671评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,825评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,729评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,614评论 2 353

推荐阅读更多精彩内容