原创--解决Javascript多行书写字符串和 ' " 转义的问题

原文出自:http://www.cnblogs.com/JiangHuakey/archive/2013/05/27/3101367.html

javascript不像python那样可以方便地多行书写字符串,比如python可以这样写字符串:

mStr="""
   line1
   line2
   'line3'
"""

而javascript只能用 + 与拼装起来

mStr="line1"+
      "line2"+
      "'line3'";

由于习惯了python的这种用法,用起来javascript就特不爽。昨晚下班后回到房间打坐冥思,灵机一动,啊哈!原来javascript也可以方便地进行多行书写。原理是构造一个函数,在函数内

写注释,如

复制代码
fun=function(){
    /*
         line1
         line2
         line3
   */
}
复制代码

然后把这个fun变成字符串,只需简单地和一个空字符串相加即可:

funStr=fun+"";

那么就会得到像下面这样的字符串

复制代码
"function(){
    /*
         line1
         line2
         line3
   */
}"
复制代码

然后再写一个函数去提取这个字符串注释里的内容即可。而且不用处理 ' "的转义。

完整代码和示例请看下面:

复制代码
<html>
<head>
    <meta http-equiv="content-type" content="text/html;charset=gbk">
    <script>
        function $string(fun){
            var funStr=fun+"";
            var reg=/\/\*/img;
            var r=reg.exec(funStr);
            var start=null;
            var stop=null;
            if(r){
                start=reg.lastIndex;
                reg=/\*\//img;
                r=reg.exec(funStr);
                if(r){
                    stop=reg.lastIndex;
                    return funStr.substring(start,stop-2);
                }
            }
            throw "语法错误..."
        }
        var myString=$string(
            function(){ 
                /*
                    <table>
                        <tr>
                            <td>用户名</td><td>密码</td>
                        </tr>
                        <tr>
                            <td style="widht:20px;">@name</td><td>zf123456</td>
                        </tr>
                    </table>
                */
            }
        );
        alert(myString);
    </script>
</head>
<body>

</body>
</html>
复制代码
posted on 2013-05-27 14:03  YOXIsky  阅读(480)  评论(0编辑  收藏  举报