浏览器无法识别包含外部javascript / jquery文件

时间:2014-03-03 17:07:07

标签: javascript jquery html jsp

在我使用Spring MVC框架开发的Dynamic Web Project(Eclipse)中,我有下面的JSP页面,放在WEB-INF / jsp /文件夹中:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  <title>HorarioLivre</title>

  <script src="http://code.jquery.com/jquery-2.1.0.min.js"></script>
  <script src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.10.4/jquery-ui.min.js"></script>
  <script src="js/index.js"></script>

  <link rel="stylesheet" href="css/style-main.css">
  <link rel="stylesheet" href="css/style-popup.css">
</head>
<body>
  <header>
    <div class="container">
      <h1><a href="#">HorarioLivre</a></h1>
      <nav>
        <ul>
          <li><a href="listagem_evento.html" class="icon evento">Eventos</a></li>
          <li><a href="cadastra_horario.html" class="icon horario">Cadastrar Horarios</a></li>
          <li><a href="listagem_horario.html" class="icon horario">Listar Horarios</a></li>
          <li><a href="listagem_usuario.html" class="icon usuario">Usuarios</a></li>
          <li><a href="#">${usuario.nome}</a>
            <ul>
                <li><a href="usuario_perfil.html" class="icon perfil">Perfil</a></li>
                <li><a href="usuario_config.html" class="icon settings">Configura&ccedil;&otilde;es</a></li>
                <li><a href="#">Logout</a></li>
            </ul>
          </li>
        </ul>
      </nav>
    </div>
  </header>
  <div id="results">
        <a href="#" id="close">Fechar</a>
        <div id="content"></div> 
  </div>  
</body>
</html>

我的问题是显然应用程序没有读取放在文件夹WebContent / js中的js / index.js文件(放置在WebContent / css中的css文件正常读取)。当我将一些javascript / jquery代码直接放在JSP页面中时(就像问题Browser doesn't recognize javascript / jquery code中显示的代码一样),它们执行时没有任何问题。

有人可以通过此页面找到问题吗?

更新1

$(document).ready(function(){
   setupPopup();
});

function setupPopup() {
   $('a').click(function() {
       $('#content').load($(this).attr('href'));
      $('#container').append('<div id="cover">');
      $('#results').fadeIn(500);
      popupPosition();
   });

   $('#close').click(function() {
      $('#results').fadeOut(100);
      $('#cover').remove();
   });

   $(window).bind('resize', popupPosition);
}

function popupPosition() {
   if(!$("#results").is(':visible')){ return; }

   $("#results").css({
      left: ($(window).width() - $('#results').width()) / 2,
      top: ($(window).width() - $('#results').width()) / 7,
      position:'absolute'
   });

   $('#results').draggable();
}

最终更新

最后,我选择不使用jquery,并通过这个替换标题中的代码:

<script>
  function handleClick(url){
      document.getElementById("results").style.display = 'block';
      document.getElementById("content").innerHTML='<object type="text/html" data="'+url+'" ></object>';
      }
  function cleanDiv() {
      document.getElementById("results").style.display = 'none';
      document.getElementById("content").innerHTML=' ';
  }
  </script>

每个链接都有这种格式:

<a href="#" onclick="handleClick('listagem_evento.html')" class="icon evento">Eventos</a>

我的弹出窗口的html代码得到以下形式:

<section class="about" id="results" style="left: 183px; top: 111px;" onMouseDown="dragStart(event, 'results');">
    <div align="right"><a href="#" class="classname" onclick="cleanDiv()">X</a></div>
    <div id="content" align="center"></div>
  </section>

随着parte style =“left:183px; top:111px;” onMouseDown =“dragStart(event,'results');”负责在屏幕上移动弹出窗口(请参阅问题how to drag and drop a <div> across the page

3 个答案:

答案 0 :(得分:0)

我不完全确定,但我想我之前已经看过这件事: 从您的js来源中删除http:https:。所以看起来应该是这样的:

<script src="//code.jquery.com/jquery-2.1.0.min.js"></script>
<script src="//ajax.googleapis.com/ajax/libs/jqueryui/1.10.4/jquery-ui.min.js"></script>

这可能不起作用,这只是我的想法。

答案 1 :(得分:0)

请尝试<script src="/js/index.js"></script>

编辑:这个Absolute path & Relative Path更详细地解释了相对和绝对路径。

我建议您在浏览器中运行JSP后查看源代码(右键单击 - 查看页面源代码或类似内容,具体取决于您的浏览器)。您应该看到页面尝试加载的JS的URL,并且应该能够相应地更正它。

此外,也许只是URL中缺少您的上下文路径。在这种情况下,我会在生成网址时使用<c:url>标记。

答案 2 :(得分:0)

这不是最佳解决方案,但您可以尝试使用jQuery.load动态加载脚本

<script>document.write('<script src="js/vendor/jquery-1.10.1.min.js"><\/script>')</script>