编程语言
首页 > 编程语言> > 使用Spring MVC的JavaScript不起作用

使用Spring MVC的JavaScript不起作用

作者:互联网

我下载了使用css和JavaScript的登录模板.当我以默认的html格式启动它时显示确定,但是当我将相同的代码放到我的Spring MVC 3应用程序并将格式更改为jsp时,javascript部分被禁用.我可以通过我的网络浏览器访问外部js文件,所以我不知道问题出在哪里.

这是正确的看法:

但这就是我得到的:

<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>

谢谢.

编辑:

我知道现在的问题在哪里,但仍然不知道如何解决它…问题出在外部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 ...>可能吗 ?

解决方法:

<script type="text/javascript" src="${pageContext.request.contextPath}/js/niceforms.js"></script>
<link href="${pageContext.request.contextPath}/css/niceforms-default.css" rel="stylesheet" />

使用上面的代码..您需要动态指定它,而不是静态指定..

标签:javascript,spring-mvc,web-applications,tiles2
来源: https://codeday.me/bug/20191007/1864049.html