您的位置:首页 > Web前端 > JavaScript

javascript正则表达式之匹配任何字符和非贪婪匹配

2017-06-19 10:06 447 查看
 大家看到这个标题会不会说 直接用正则表达式的. 号不就可以了吗 。是的一般代码用就可以了,现在我用rhino(一种java写的javascript解析器,里面有不少API,如文件读取等,那我们可以用javascript来读取本地文件来进行文件的合并工作了,这个和用windows script 中的new ActiveX('FileSystemObject')也差不多 )。

     在读取文件后,里面有许多换行的。比如有一段文本

 

{{begin GIFT.tmpl.sendListPageDiv}}

<%for(var i=startPage-0;i<=endPage-0;i++){ if(i==curPage){ %>

<strong class="current_page">

<%=i%>

</strong>

<%}else{%>

<a href="javascript:void(0);" page="<%=i%>">

<%=i%>

</a>

<%}}%>

{{end GIFT.tmpl.sendListPageDiv}}

 

 

我想把{{begin...}}到{{end...}}中的文件读取出来,对其进行html压缩,读取的时候发现这样用(QZAPP为另人写的一套API,里面的toString函数有html压缩功能)

//s为读取到的文本内容字符串

function replaceStr (s){

    return s.replace(/\{\{\s*begin\s+([\.\w]+)\s*\}\}(.*)\{\{\s*end\s+\1\s*\}\}/g, function(a,b,c,d){

            var ret = b+'= \''+QZAPP.toString(c)+'\';';

            if(c.length == 0){

            QZAPP.log("<--error-->:empty replacestr");

        }

        return ret;

    });

}

红色部分这样写发现读取不到内容,查了下书, 点号匹配:除换行符和其他Unicode行终止符之外的任意字符的任意字符,改成

([^]*)  

OK 读取到了。

PS:本例子中有一个问题,红色部分是读取任何内容,正则表达式用的是贪婪匹配,如果后部不用唯一标记的匹配法如:

 return s.replace(/\{\{\s*begin\s+([\.\w]+)\s*\}\}([^]*)\{\{\s*end\s*\}\}/g, function(a,b,c,d){

,会出现

{{begin GIFT.tmpl.sendListPageDiv}}

。。。。

{{end}}

 

{{begin GIFT.tmpl.sendListPageDiv2}}

。。。。

{{end}}

绿色部分一直匹配到蓝色那里,当然用非贪婪匹配?就可以了,如

 return s.replace(/\{\{\s*begin\s+([\.\w]+)\s*\}\}([^]*?)\{\{\s*end\s*\}\}/g, function(a,b,c,d){
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息