strToHtml

纯属娱乐,稍微修改一下,可以改成类似一个模板引擎的东西。

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
var strToHtml = (function(){
    var boundaryReg = /[+>]/,relationReg = /[+>]/g,classReg = /\.(\w+)/,idReg=/#(\w+)/,repeatReg=/\*(\d+)/,typeReg=/\:(\w+)/,tagReg = /^\w+/;
    var h,r;
    function expand(str){
        var node = document.createElement(str.match(tagReg)[0]),c,frag = document.createDocumentFragment();
        if(classReg.test(str)) node.className = RegExp.$1;
        if(idReg.test(str)) node.id = RegExp.$1;
        if(typeReg.test(str)) node.type = RegExp.$1;
        if(repeatReg.test(str)){
            c = RegExp.$1-0;
            for(var i=0;i<c;i++){
                frag.appendChild(node.cloneNode(true));
            };
            return frag;
        };
        frag.appendChild(node);
        return frag;
    };
    function combine(ret,r){
        var p,n,g,c;
        n = ret.pop();
        while(ret.length){
            p = ret.pop();
            g = r.pop();
            c = p.childNodes;
            if(g){
                if(g == '>'){
                    for(var i=0,len=c.length;i<len;i++){
                        c[i].appendChild(n.cloneNode(true));
                    };
                };
                if(g == '+'){
                    p.appendChild(n);
                };
                n = p;
            }
        };
        return p;
    };
 
    return function(str,parent){
        if(!str) return '';
        var ret =[];
        parent = parent || document.body;
        h = str.split(boundaryReg);
        r = str.match(relationReg);
        for(var i=0,len=h.length;i<len;i++){
            ret.push(expand(h[i]));
        };
        parent.appendChild(combine(ret,r));
    };
})();

posted @   zjhsd2007  阅读(974)  评论(4编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
点击右上角即可分享
微信分享提示