我使用RequireJS在网站上有多个页面,并且大多数页面都具有独特的功能。它们共享许多通用模块(jQuery,Backbone等);所有这些都有自己独特的模块。我想知道使用r.js优化此代码的最佳方法是什么。我看到了RequireJS和Almond的文档和示例的不同部分提出的一些替代方案 - 所以我想出了以下我看到的可能性列表,我问最推荐哪一个(或者是否有另一种更好的方法) :
data-main
语法或普通<script>
标记在所有页面上的公共模块之前加载文件require.js - 根本不使用Almond。这意味着每个页面都有三个JS文件:require.js,通用模块和特定于页面的模块。
湾似乎this gist建议将Almond插入每个优化文件的方法----所以我不必加载require.js,而是在我的公共模块和我的页面中包含Almond模块。是对的吗?这比提前加载require.js更有效吗?感谢您提供有关实现这一目标的最佳方式的任何建议。
答案 0 :(得分:35)
我认为你已经很清楚地回答了你自己的问题。
对于生产,我们 - 以及我使用选项3 的大多数公司。
以下是解决方案3的优点,以及为什么我认为你应该使用它:
这是解决方案2的一个有趣优势:
您向每个页面发送最少的数据。如果您的很多访问者都是一次,例如在目标网页中 - 这是您最好的选择。在面向转换的场景中,加载时间的重要性不容小觑。
您的访客是否重复? some studies表示有40%的访问者拥有空缓存。
其他考虑因素:
如果您的大多数访问者访问单个页面 - 请考虑选项2.选项3非常适合普通用户访问多个网页的网站,但如果用户访问单个网页并且他只看到了 - 那就是您的最好的选择。
如果你有很多的JavaScript。考虑加载其中一些以给用户提供可视指示,然后以延迟方式异步加载其余部分(使用脚本标记注入,或者如果您已经使用它,则直接使用require)。在UI中注意某些东西“笨重”的人的阈值通常是大约100毫秒。一个例子是GMail的'loading ...'。
鉴于HTTP / 1.1中默认情况下HTTP连接为Keep-Alive或HTTP / 1.0中有额外的标头,发送多个文件的问题比5 - 10年前少。确保从服务器为HTTP / 1.0客户端发送Keep-Alive
标头。
一些一般性建议和阅读材料:
答案 1 :(得分:14)
答案 2 :(得分:1)
仅供参考,我更喜欢使用选项3,遵循https://github.com/requirejs/example-multipage-shim
中的示例我不确定它是否效率最高。
然而,我发现它很方便,因为:
答案 3 :(得分:0)
我更喜欢使用选项3,我可以肯定地告诉你为什么会这样。
我列出了更好的选择。
答案 4 :(得分:0)
您可以使用MaxCDN之类的任何内容投放网络(CDN)来确保将js文件提供给所有人。另外我建议你把你的js文件放在你的html代码的页脚里。希望有所帮助。