Я загрузил шаблон входа, который использует css и JavaScript. Когда я запускаю его в формате html по умолчанию, он отображается нормально, но когда я помещаю тот же код в приложение Spring MVC 3 и меняю формат на jsp, часть javascript отключается. Я могу получить доступ к внешним файлам js через свой веб-браузер, поэтому я не знаю, где может быть проблема.JavaScript с Spring MVC не работает
Это правильный взгляд:
, но это то, что я получаю:
<script language="javascript" type="text/javascript" src="js/niceforms.js"></script>
<link rel="stylesheet" type="text/css" media="all" href="css/niceforms-default.css" />
Я только изменил расположение внешних JS и CSS ресурсов, но эти файлы, доступные как я сказал.
Это моя структура:
В моей web.xml
я эти строки:
<!-- The definition of the Root Spring Container shared by all Servlets and Filters -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
/WEB-INF/spring/root-context.xml,
/WEB-INF/spring/security-context.xml,
</param-value>
</context-param>
<!-- Creates the Spring Container shared by all Servlets and Filters -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- Processes application requests -->
<servlet>
<servlet-name>appServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/spring/appServlet/servlet-context.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>appServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<!-- Spring Security -->
<filter>
<filter-name>springSecurityFilterChain</filter-name>
<filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>
<filter-mapping>
<filter-name>springSecurityFilterChain</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.css</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.js</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.gif</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.jpg</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.png</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.txt</url-pattern>
</servlet-mapping>
Я также использовать Apache tiles2
<tiles-definitions>
<definition name="base.definition" template="/WEB-INF/views/layout/layout.jsp">
<put-attribute name="body" value="" />
</definition>
<definition name="contact" extends="base.definition">
<put-attribute name="body" value="/WEB-INF/views/contact.jsp" />
</definition>
<definition name="login" template="/WEB-INF/views/login/login.jsp">
</definition>
Спасибо.
Edit:
Я знаю, где проблема сейчас, но до сих пор не знает, как ее решить ... Проблема в дорожках во внешних CSS-файлах. У меня есть что-то вроде этого: body {background-image:url('images/bg.jpg');}
, но я не нашел ошибку в firebug, потому что он пытается найти ресурс в localhost: 8080/sheedo/css/images/bg.jpg и когда я устанавливаю абсолютный путь ресурса, например body {background-image:url('/images/bg.jpg');}
Я получаю такая же ошибка, но она пытается найти ее в localhost: 8080/images/bg.jpg. Когда я использую ./images/bg.jpg
, все в порядке, но существует ли какое-либо другое решение вместо того, чтобы переписывать все пути в файлах css? Я имею в виду что-то вроде <mvc:resources ... >
это возможно?
Что ошибка JS вы видите? -> Firebug в FF или "inpect element" в Chrome/Safari ... – nickdos
Спасибо за подсказку с firebug. Посмотрите на мое редактирование. –