zzy

2025.2.18

代码优化

考虑到后续有较多重复操作(不同标识的处理都是类似的), 因此我们把重复的部分提取出来, 让函数变得更通用, 方便后续开发.

效果展示

与上一节无差异, 略

问题分析

原始代码

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
document.addEventListener('DOMContentLoaded', (event) => {
const input = document.getElementById('input');
const output = document.getElementById('output');
input.addEventListener('input', (event) => {
// 考虑添加防抖

output.innerHTML = handleinput(input.value);
});
});

function handleinput(ori){
// 去空
let oris = ori.split('\n');
let filter = []
for (let i of oris){
if (i){
filter = [...filter, i]
}
};
// 多级标题
let title = []
for (let i of filter) {
if (i[0] == '#' && /#+\s/.test(i)){
let n = i.match(/#+\s/)[0].length;
console.log(i.match(/#+\s/)[0])
i = `<h${n-1}>${i.slice(n)}</h${n-1}>`
// console.log(i)
}
title = [...title, i]
};
// console.log(title)

let rows = []
for (let i of title){
if (i){
rows = [...rows, `<p>${i}</p>`]
}
};
// 分行

md = rows.join('\n')
return md
};

要点提取

  1. 核心逻辑
本文作者:zzy
本文链接:http://周梓煜.com/2025/02/18/Re-从零开始的markdown编辑器/md-4-/
版权声明:本文采用 CC BY-NC-SA 3.0 CN 协议进行许可