springMVC使用modelAndView返回界面与数据,jstl循环list

1.必要的maven依赖

<!-- JSP相关 -->
    <dependency>
      <groupId>jstl</groupId>
      <artifactId>jstl</artifactId>
      <version>1.2</version>
    </dependency>
    <dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>jsp-api</artifactId>
      <version>2.0</version>
      <scope>provided</scope>
    </dependency>
    <dependency>
      <groupId>javax.persistence</groupId>
      <artifactId>persistence-api</artifactId>
      <version>1.0</version>
    </dependency>
    <dependency>
      <groupId>org.apache.taglibs</groupId>
      <artifactId>taglibs-standard-impl</artifactId>
      <version>1.2.5</version>
    </dependency>

2.后台获取的json数据格式

{
    "msg":"success",
    "code":0,
    "page":{
        "total":4,
        "list":[
            {
                "bname":"颁布天数",
                "is_flag":"0",
                "bid":1,
                "type":"1",
                "bprice":"12",
                "bimg":"15407361597941231.jpg"
            },
            Object{...},
            Object{...},
            Object{...}
        ],
        "pageNum":1,
        "pageSize":8,
        "pages":1,
        "size":4
    }
}

3.jsp界面代码

<%@ page language="java" contentType="text/html; charset=UTF-8"
         pageEncoding="UTF-8"%>
<%--必须引入的--%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<html>
<head>
    <title>mybaties分页</title>
    <link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
</head>
<body>
<%--动态引入项目地址,方便部署--%>
<%
    String path = request.getContextPath();
    String ppath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort();
    String basePath = request.getScheme() + "://"
            + request.getServerName() + ":" + request.getServerPort()
            + path;
%>
<div style="width: 600px;height: 300px;background-color: whitesmoke">
    <table class="table table-striped">
        <thead>
        <tr>
            <th>书名</th>
            <th>价格</th>
            <th>分类</th>
            <th>图片</th>
        </tr>
        </thead>
        <tbody>
        <c:forEach items="${requestScope.list}" var="book" >
            <tr>
                <td>${book.bname}</td>
                <td>${book.bprice}</td>
                <td>${book.type}</td><%--http://localhost:8080/onlineBooklib/statics/upload/--%>
                <td ><img style="overflow: hidden;width: 70px;height: 70px;" src="<%=basePath%>/upload/${book.bimg}"></td>
            </tr>
        </c:forEach>
        </tbody>
    </table>
</div>
</body>
</html>

4.总结,开始以为jstl和Thymeleaf一样,使用${list}就可以得到循环变量,并且误以为items就是我要循环的那个变量,百度之后才知道 jstl的变量var=“key”
以下是对比:
Thymeleaf的循环

<tbody th:each="item : ${list}"   >
<tr>
<td><span th:text="${item.bname}"></span></td>
<td><span th:text="${item.bprice}"></span></td>
</tr>
</tbody>

jstl的循环

<c:forEach items="${requestScope.list}" var="book" >
            <tr>
                <td>${book.bname}</td>
                <td>${book.bprice}</td>
            </tr>
        </c:forEach>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值