-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path01-template.js
72 lines (63 loc) · 2.43 KB
/
01-template.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
module.exports = {
compile(template) {
// 转换template
// 希望输出:<b>${key}</b>
// 返回我们的generate函数
// (.+?)可以匹配多个 {{name}} (.+)只能匹配单个 {{name}}
// (.+)默认是贪婪匹配 (.+?) 为惰性匹配
template = template.replace(/\{\{(.+?)\}\}/g, function () {
// console.log(arguments);
const key = arguments[1].trim();
return "${" + key + "}";
});
const body =
"let str = ''; with(obj) { str += `" + template + "`} return str";
return new Function("obj", body);
},
};
// let template = '我是{{name}},年龄{{age}},性别{{sex}}';
// let data = {
// name: '姓名',
// age: 18
// }
// render(template, data); // 我是姓名,年龄18,性别undefined
// function render(template, data) {
// const reg = /\{\{(\w+)\}\}/; // 模板字符串正则
// if (reg.test(template)) { // 判断模板里是否有模板字符串
// console.log(reg.exec(template))
// const name = reg.exec(template)[1]; // 查找当前模板里第一个模板字符串的字段
// template = template.replace(reg, data[name]); // 将第一个模板字符串渲染
// return render(template, data); // 递归的渲染并返回渲染后的结构
// }
// return template; // 如果模板没有模板字符串直接返回
// }
// function render(template, data) {
// // /\{\{(\w+)\}\}/ === /\{\{(.+?)\}\}/
// const reg = /\{\{(\w+)\}\}/g
// template = template.replace(reg, function (x) {
// console.log(arguments, x)
// return data[arguments[1]]
// })
// console.log(template)
// // console.log(reg.exec(template))
// }
// let s1 = "get-element-by-id"
// s1 = s1.replace(/-\w/g, function (x) {
// console.log(x)
// return x[1].toUpperCase()
// })
// console.log(s1)
// 查找字符串中出现最多的字符和个数 先排序再正则匹配
let s2 = 'aaabbbbbcccccccc'
s2.replace(/(\w)\1+/g, function () {
console.log(arguments)
})
function render(template, data) {
const reg = /\{\{(\w+)\}\}/; // 模板字符串正则
if (reg.test(template)) { // 判断模板里是否有模板字符串
const name = reg.exec(template)[1]; // 查找当前模板里第一个模板字符串的字段
template = template.replace(reg, data[name]); // 将第一个模板字符串渲染
return render(template, data); // 递归的渲染并返回渲染后的结构
}
return template; // 如果模板没有模板字符串直接返回
}