multiline.js帮你在js当中实现多行文本

multiline.js帮你在js当中实现多行文本

想在js当中使用多行字符串?multiline.js帮你实现这个愿望!

var str = multiline(function(){/*
<!doctype html>
<html>
    <body>
        <h1>❤ unicorns</h1>
    </body>
</html>
*/});

上面是来自github repo的示例,可以看出multiline.js是将注释当中的内容截取下来,生成的字符串,内部实现也比较简洁:

...
var reCommentContents = /\/\*!?(?:\@preserve)?[ \t]*(?:\r\n|\n)([\s\S]*?)(?:\r\n|\n)\s*\*\//;

var multiline = module.exports = function (fn) {
    ...
    var match = reCommentContents.exec(fn.toString());
    ...
};
...

关键之处就在于function的toString方法,requirejs使用了用同样的方法去解析模块的依赖关系

但是这个模块有一个问题,我们经常需要压缩js代码来优化性能,很多的压缩方式默认会去除注释,这就会导致mutiline抛出异常,好在作者Sindre Sorhus说明了解决方式

原文链接:http://jarvys.github.io/2014/05/29/multilinejs/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容