我的JSP

时间:2017-01-14 13:57:16

标签: java spring jsp spring-mvc jstl

我已经构建了一个简单的应用程序来使用JQuery Data table + Spring + DB显示一些数据。数据显示为表格。

我最初构建了我的后端模型+ DB(MongoDB)+ View,它有两个显示正常的属性。

但是现在当我向我的所有图层添加更多属性时,JSP并没有向我显示新添加的属性的值。

我已经检查过我的控制器正在模型中发送正确的值作为对JSP的响应。似乎JSP中的JSTL标记没有显示正确的值。

我的模型中有5个属性。

姓名,年份,导演,评级,排名。

在工作正常之前添加了

名称和年份。

导演,评级和排名后来添加,不起作用。下面我给出了我的模型类的代码。

以下是我的jSP代码

      <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
        pageEncoding="ISO-8859-1"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
    <title>My Movie Manager</title>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
    <link rel="stylesheet" href="main.css" />
    <link rel="stylesheet" type="text/css" href="//cdn.datatables.net/1.10.13/css/jquery.dataTables.css">
    <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
    <script type="text/javascript" charset="utf8" src="//cdn.datatables.net/1.10.13/js/jquery.dataTables.js"></script>

    </head>
    <body>
     <h1>Welcome to My movie manager</h1>
        <h3>My ranking of movies</h3>
        <input type="button" value="Add a new movie" id="addbtn" />
        <input type="button" value="Select and remove a movie" id="delbtn" />
        <br><br>
        <table id="table_id" class="display">
        <thead> 
            <tr>
                <th>My Ranking</th>
                <th>Name</th>
                <th>Year</th>
                <th>Rating</th>
                <th>Director</th>

            </tr>
        </thead>
        <tbody>
            <c:forEach items="${movieslist}" var="movie">
            <tr>
                <td>$(movie.ranking)</td>
                <td>${movie.name}</td>
                <td>${movie.year}</td>
                <td>$(movie.rating)</td>
                <td>$(movie.director)</td>
            </tr>

            </c:forEach>
        </tbody>
    </table>
</body>
<script>

$(document).ready( function () {
    var table = $('#table_id').DataTable();
    $('#addbtn').click(addrow);
    $('#delbtn').click(delrow);


    table.on( 'click', 'tr', function () {
        if ( $(this).hasClass('selected') ) {
            $(this).removeClass('selected');
        }
        else {
            table.$('tr.selected').removeClass('selected');
            $(this).addClass('selected');
        }
    } );
} );
</script>
</html>

下面是我的Spring控制器

   @Controller
@RequestMapping("/movies")
public class MovieController{

    protected final Log logger = LogFactory.getLog(getClass());

    @RequestMapping(method = RequestMethod.GET)
    public String getMovies(Model model) {
        // TODO Auto-generated method stub
        logger.info("returning hello view");
        List<Movies> moviesList = DbManager.getInstance().getMovies();

        model.addAttribute("movieslist", moviesList);
        return "hello";
    }
}

以下是我的域类

 package springapp.domain;

import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;
@Document(collection = "movies")
public class Movies {

    @Id
    public String _id;

    public String name;
    public String year;
    public String director;
    public float rating;
    public int ranking;
    public int getRanking() {
        return ranking;
    }

    public void setRanking(int ranking) {
        this.ranking = ranking;
    }

    public String getDirector() {
        return director;
    }

    public void setDirector(String director) {
        this.director = director;
    }

    public float getRating() {
        return rating;
    }

    public void setRating(float rating) {
        this.rating = rating;
    }

    public String getYear() {
        return year;
    }

    public void setYear(String year) {
        this.year = year;
    }

    public String getId() {
        return _id;
    }

    public void setId(String _id) {
        this._id = _id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }



    @Override
    public String toString() {
        // TODO Auto-generated method stub
        return name;
    }

}

1 个答案:

答案 0 :(得分:1)

请按以下方式更正:

  1. 使用$ {} no $()。它应该是

                              

                <td>${movie.myranking}</td>
                <td>${movie.name}</td>
                <td>${movie.year}</td>
                <td>${movie.rating}</td>
                <td>${movie.director}</td>
            </tr>
    
    
        </tbody>