vue核心之AST
前端
0
709
0
发表于: 2021-04-18 19:11:34
简介: 暂无~
什么是AST
AST是指抽象语法树(abstract syntax tree缩写即AST)
模板转化为AST(简易版)
index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script type="text/template" id="ast">
<div>
<h1>你好</h1>
<ul>
<li>你好啊A</li>
<li>好的B</li>
<li>收到了C</li>
</ul>
</div>
</script>
<script src="./parse.js"></script>
<script>
var str = document.getElementById('ast').innerHTML
console.log(str)
parse(str)
</script>
</body>
</html>
parse.js
function parse(templateStr) {
// 当前遍历到的位置
var index = 0
// 栈1保存标签
var stack1 = []
// 栈2保存结果
var stack2 = [{ children: [] }]
// 剩余的模板字符串(即没遍历到的)
var lastStr = templateStr
// 匹配开始标签(注意这里的正则最后不要加全局的g,否则会出现问题)
var startTagReg = /^<([a-z]+[1-6]?)>/
// 匹配结束标签(注意这里的正则最后不要加全局的g,否则会出现问题)
var endTagReg = /^<\/([a-z]+[1-6]?)>/
// 这里只匹配开始标签到结束标签之间的文字,不匹配结束标签到开始标签之间的文字
var wordTagReg = /^([^\>]+)<\/([a-z]+[1-6]?)>/
// var wordTagReg = /^>([^\>]+)<\/([a-z]+[1-6]?)>/
while (index < templateStr.length) {
if (startTagReg.test(lastStr)) {
var startTag = lastStr.match(startTagReg)[1]
console.log('找到开始标签', startTag)
// console.log(index)
index += startTag.length + 2
stack1.push({ tag: startTag, children: [], isRoot: true })
stack2.push({ tag: startTag, children: [] })
} else if (endTagReg.test(lastStr)) {
var endTag = lastStr.match(endTagReg)[1]
console.log('找到结束标签', endTag)
var c = stack2.pop()
stack2[stack2.length - 1].children.push(c)
index += endTag.length + 3
} else if (wordTagReg.test(lastStr)) {
var wordTag = lastStr.match(wordTagReg)[1]
index += wordTag.length
if (!/^\s+$/.test(wordTag)) {
stack2[stack2.length - 1].children.push({ text: wordTag })
} else {
// console.log('全是空字符串')
}
} else {
// 啥都没找到
console.log('没匹配到标签以及开始到结束标签之间的文字', lastStr)
index++
}
lastStr = templateStr.substring(index)
}
console.log(stack1)
console.log(stack2)
}
待更新
最后更新于:2021-04-18 19:11:34
欢迎评论留言~
0/400
支持markdownComments | 0 条留言
登录
按时间
按热度
目前还没有人留言~