zoukankan      html  css  js  c++  java
  • parseHTML2Vnode

    var startReg = new RegExp(/^<[^/>]+>/);
    var selfCloseReg = new RegExp(/^<[^<>/]+/>/);
    var endReg = new RegExp('^</[^>]+>');
    var textNode = new RegExp(/^[^<]+/);
    
    function parse(html) {
        var stack = [];
        var res;
        while (html) {
            var startTag = startReg.exec(html);
            if (startTag) {
                res = startTag[0];
                stack.push(res);
                html = html.slice(res.length);
                continue;
            }
            var textTag = textNode.exec(html);
            if (textTag) {
                res = textTag[0];
                stack.push(res);
                html = html.slice(res.length);
                continue;
            }
            var endTag = endReg.exec(html);
            if (endTag) {
                res = endTag[0];
                stack.push(res);
                html = html.slice(res.length);
                continue;
            }
            var selfCloseTag = selfCloseReg.exec(html);
            if (selfCloseTag) {
                res = selfCloseTag[0];
                stack.push(res);
                html = html.slice(res.length);
                continue;
            }
        }
        return stack;
    }
    
    var template = '<div id="main">name</div><span class="loading"><input type="text" />name</span>';
    
    console.log(parse(template));
  • 相关阅读:
    HDU 1540 Tunnel Warfare (线段树区间合并)
    P2258 子矩阵
    P5021 赛道修建
    P4084 [USACO17DEC]Barn Painting
    P3914 染色计数
    比赛用模板
    P3594 [POI2015]WIL-Wilcze doły
    P5022 旅行
    P3952 时间复杂度
    P3960 列队
  • 原文地址:https://www.cnblogs.com/jiajiaobj/p/13654967.html
Copyright © 2011-2022 走看看