我看到this question重新导入与标记内容本身相关的js文件。我有一个类似的问题,这里我有一个生成一些HTML的jsp标签,并有一个通用的js实现来处理这个HTML的行为。此外,我需要编写一些初始化语句,因此我可以通过JavaScript使用它。为了能够在我的JavaScript中使用这个“处理程序”,它应该以某种方式可访问。
问题是......编写内联< script>是否可以?标签以及我的HTML用于实例化和初始化目的(我个人认为它不是很优雅)?关于JS世界的可访问性,我是否应该保留一个全局变量引用我的处理程序对象(我认为不是很优雅),有更好的方法吗?
答案 0 :(得分:9)
你应该在自己的文件中争取使用javascript。这通常使用Progressive Enhancement完成。但有些时候你没有选择,例如当同一个JSP呈现不同语言的页面时。这是一个真实的例子:
JSP:
<script src="/javascript/article_admin.js"></script>
<script type="text/javascript">
NP_ArticleAdmin.initialize({
text: {
please_confirm_deletion_of: '<i18n:output text="please.confirm.deletion.of"/>',
this_cannot_be_undone: '<i18n:output text="this.cannot.be.undone"/>'
}
});
</script>
javascript(article_admin.js):
/*global NP_ArticleAdmin, jQuery, confirm */
NP_ArticleAdmin = function ($) {
var text;
function delete_article(event) {
var article = $(this).parents("li.article"),
id = article.attr("id"),
name = article.find("h3.name").html();
if (confirm(text.please_confirm_deletion_of + name + text.this_cannot_be_undone)) {
$.post("/admin/delete_article", {id: id});
article.fadeOut();
}
event.preventDefault();
return false;
}
function initialize(data) {
text = data.text;
$("#articles a.delete").click(delete_article);
}
return {initialize: initialize};
}(jQuery);
在此示例中,JSP文件中唯一的javascript是需要存在的部分。核心功能在其自己的js文件中分开。
答案 1 :(得分:1)
我不完全确定你在这里问的是什么,但是我没有在JSP中包含<script>
标签以实例化javascript代码。我经常遵循这个模型,在外部javascript文件中编写库代码,然后从<script>
标签调用构造函数到我的对象。
这使得调试变得容易,因为逻辑全部在外部文件中(并且firebug似乎在调试内联javascript代码时遇到问题)。库被缓存,但实例化它们的数据却没有(这是所需的行为)。
另一种方法是在外部javascript文件或AJAX调用中动态生成实例化代码。我也是这样做的,结果很好。
我认为决定因素是您拥有多少动态数据。如果您需要表示大型数据结构,我会通过返回JSON的AJAX调用来提供它。如果它是对构造函数的简单调用,则将其放在JSP中。
至于全局变量,我经常会有一个顶级对象的全局变量,它可以解决所有问题。在其中,是对辅助对象的所有其他引用。
答案 2 :(得分:0)
虽然我同意它并不完全优雅,但在将服务器端决策与AJAX集成环境相结合时,我已经知道这样做了几次。回应内联&lt; script&gt;标签为了初始化一些变量并不是一件可怕的事情,只要没有人看到它。
至于更好的方法,我不知道这些。我很少这么做,所以我没有寻求更优雅或“适当”的解决方案。
答案 3 :(得分:0)
使用符合HTML的<script>
标记即可。有时需要它,但就我认识的任何更好的方法而言。在不使事情变得更复杂的情况下,使用<script>
标签然后尝试找到实现js文件的方法会更容易。