简介:
这里使用EL表达式获取的数据都要先在Servlet里面进行封装,才能在jsp里面获取
新建Servlet并准备数据存储到request域里面然后使用资源转发到.jsp文件里
package org.example.web;import org.example.pojo.Brand;import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;@WebServlet("/demo1")
public class Servletdemo1 extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {//1.准备数据,模拟数据库查询结果List brands = new ArrayList();brands.add(new Brand(1,"三只松鼠","三只松鼠",100,"三只松鼠,好吃不上火",1));brands.add(new Brand(2,"优衣库","优衣库",200,"优衣库,服适人生",0));brands.add(new Brand(3,"小米","小米科技有限公司",1000,"为发烧而生",1));//2.存储数据到request数据域里面request.setAttribute("brands",brands);//3.转发到eldemo.jsprequest.getRequestDispatcher("/eldemo.jsp").forward(request,response);}@Overrideprotected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {}
}
在jsp文件里面使用${}进行访问
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
Title
${brands}
访问对应Servlet后结果如下,相应数据都获取到了
page只在当前的jsp页面有效
request可以在一次请求转发的多个资源之间有效。
application在整个web应用程序有效
四个域的范围的关系
新建一个jsp文件,如下使用,在test=""的冒号里面要写一个逻辑判断的表达式
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
Title
<%--
c-if:完成逻辑判断,替换的if-else代码
--%>
TRUE
FALSE
运行服务器输出如下
结合EL表达式使用request域当中过的数据进行判断
启用
禁用
在Servlet中加上
request.setAttribute("status",1);
这里要先访问Servlet资源,转发到jstl.jsp页面上去,输出如下
使用方式
新建一个jstl-foreach。jsp文件
foreach标签里面有两个属性,一个是要遍历的容器,另一个是遍历容器时产生的对象
获取属性时使用.id的方式,点后面的部分会先被变成开头首字母大写Id,然后会自动在方法里面找到getId方法然后进行获取。
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page import="org.example.pojo.Brand" %>
<%@ page import="java.util.ArrayList" %>
<%@ page import="java.util.List" %>
<%//查询数据库List brands = new ArrayList();brands.add(new Brand(1,"三只松鼠","三只松鼠",100,"三只松鼠,好吃不上火",1));brands.add(new Brand(2,"优衣库","优衣库",200,"优衣库,服适人生",0));brands.add(new Brand(3,"小米","小米科技有限公司",1000,"为发烧而生",1));
%>
Title
序号 品牌名称 企业名称 排序 品牌介绍 状态 操作 ${brand.id} ${brand.brandName} ${brand.companyName} ${brand.ordered} ${brand.description} ${brand.status} 修改删除
成功输出
在上面的图里面的序号使用的是数据库里的id,但一般不能这么用,如果删除了某些数据就会出现断层,这里使用foreach标签里面的一个新的属性varStatus,使用下面的两种进行代替
<%--${brand.id} --%>${status.count}
${status.index}
最后还有另外一种for循环
效果:分页工具条