news 2026/5/25 11:35:48

JSP标签JSTL标签EL表达式

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
JSP标签JSTL标签EL表达式
<dependency><!-- JSTL表达式的依赖 --><groupId>javax.servlet.jsp.jstl</groupId><artifactId>jstl-api</artifactId><version>1.2</version></dependency><!--standard标签库 --><dependency><groupId>taglibs</groupId><artifactId>standard</artifactId><version>1.1.2</version></dependency>

EL表达式:${}

  • 获取数据
  • 执行运算
  • 获取web开发的常用对象
<input type="text"name="username"value="${param.username}">
<form action="coreif.jsp"method="get"><%--EL表达式获取表单中的数据 ${param.参数名}--%><input type="text"name="username"value="${param.username}"><input type="submit"value="登录"></form>

JSP标签

转发

<jsp:forward page="jsptag2.jsp"></jsp:forward>

携带参数

可以配合转发或者文件包含使用

  • 转发的时候默认携带参数进行请求
<%--http://localhost:8081/jsptag.jsp?name=root&passwd=root--%><jsp:forward page="jsptag2.jsp"><jsp:param name="name"value="root"/><jsp:param name="passwd"value="root"/></jsp:forward>
<jsp:include page="jsptag2.jsp"><jsp:param name="name"value="root"/><jsp:param name="passwd"value="root"/></jsp:include>

取出参数

jsptag2.jsp

<%@ page contentType="text/html;charset=UTF-8"language="java"%><html><head><title>Title</title></head><body><h1>这是jsptag2的页面</h1><%--取出参数--%>用户名:<%=request.getParameter("username")%>密码:<%=request.getParameter("password")%></body></html>

jsptag.jsp

<%@ page contentType="text/html;charset=UTF-8"language="java"%><html><head><title>Title</title></head><body><%--http://localhost:8081/jsptag.jsp?name=root&passwd=root--%><jsp:forward page="jsptag2.jsp"><jsp:param name="username"value="root"/><jsp:param name="password"value="root"/></jsp:forward></body></html>

jsptag.jsp页面可以看见转发的时候默认携带参数了,而jsptag2.jsp接受参数的时候还需要在网页中输入请求的参数

文件包含

<jsp:include page="jsptag2.jsp"></jsp:include>

JSTL表达式

JSTL标签库的使用是为了弥补HTML标签的不足;它自定义了许多的标签,可以供我们使用,标签的功能和Java代码一样!

  • 格式化标签
  • SQL标签
  • XML标签
  • 核心标签(掌握部分)

核心标签

JSTL标签库使用步骤

  • 引入对应的taglib
  • 使用其中的方法
  • 在Tomcat也需要引入jstl的包,否则会报错:JSTL解析错误

c:if

核心

<c:iftest="${param.username=='admin'}"var="isAdmin"><c:out value="管理员登陆成功"/></c:if><c:iftest="${not isAdmin}"><c:out value="普通用户"/></c:if>

coreif.jsp

<%@ page contentType="text/html;charset=UTF-8"language="java"%><%--引入JSTL核心标签库,我们才能使用JSTL标签 core--%><%@ taglib prefix="c"uri="http://java.sun.com/jsp/jstl/core"%><h4>if测试</h4><hr><form action="coreif.jsp"method="get"><%--EL表达式获取表单中的数据 ${param.参数名}--%><input type="text"name="username"value="${param.username}"><input type="submit"value="登录"></form><%--判断如果提交的用户名是管理员,则登陆成功<%if(request.getParameter("username").equals("admin")){out.print("登陆成功");}%>--%><c:iftest="${param.username=='admin'}"var="isAdmin"><c:out value="管理员登陆成功"/></c:if><c:iftest="${not isAdmin}"><c:out value="普通用户"/></c:if></body></html>

c:set

定义一个变量score的值

<c:setvar="score"value="85"/>

c:choose

<c:choose><c:when test="${score>=90}">优秀</c:when><c:when test="${score>=85}">良好</c:when><c:when test="${score>=80}">还行</c:when><c:when test="${score>=70}">一般</c:when><c:when test="${score>=60}">差生</c:when></c:choose>

c:forEach

<%@ taglib prefix="c"uri="http://java.sun.com/jsp/jstl/core"%><%@ pageimport="java.util.ArrayList"%><%@ page contentType="text/html;charset=UTF-8"language="java"%><html><head><title>Title</title></head><body><%ArrayList<Object>people=newArrayList<>();people.add(0,"张三");people.add(1,"BB");people.add(2,"CC");people.add(3,"DD");people.add(4,"EE");request.setAttribute("list",people);%><%--var,每一次遍历出来的变量 items,遍历的集合 begin,哪里开始到哪里 end,到哪里 step,步长--%><c:forEachvar="people"items="${list}"><h1><c:out value="${people}"/></h1><br></c:forEach><hr><c:forEach begin="1"end="3"step="1"items="${list}"var="people"></c:forEach><%--等价于上面<%for(inti=0;i<2;i++){}%>--%></body></html>

如果是前端html弄出数据就要写50行代码,但是c:forEach 一行就够了

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/25 23:16:43

Linux操作系统自带的测试内存泄漏的命令

Linux操作系统自带的测试内存泄漏的命令&#xff1a; watch -n 1 "ps -o vsz,rss,pmem,comm -p pidof DataBridgeDeamon 通过查看&#xff1a;rss的数据变化来粗略的判断是否有内存泄漏。 在嵌入式开发和 Qt 编程中&#xff0c;内存泄漏&#xff08;Memory Leak&#xff0…

作者头像 李华
网站建设 2026/5/26 6:34:33

学读书类比大语言模型训练?通俗易懂掌握AI核心原理

大语言模型训练类比人类学习过程&#xff0c;分为三步&#xff1a;预训练从互联网学习基础知识并构建预测模型&#xff1b;监督微调通过问答数据教会模型回答问题&#xff1b;强化学习让模型自主探索最佳解决方案&#xff0c;形成思维链。本质上&#xff0c;AI大语言模型是一个…

作者头像 李华
网站建设 2026/5/25 7:49:30

AI落地六大黄金场景:从营销到政策驱动,附国内及出海成功案例,技术收藏必读

本文详细探讨了AI最有可能率先落地的六大场景&#xff1a;营销与客户运营智能化、生产流程与供应链优化、办公自动化与内部管理提效、垂直行业场景化解决方案、智能硬件与终端应用创新、政策驱动下的普惠化与生态协同。每个场景均分析了功能、实现方式及成功案例&#xff08;包…

作者头像 李华
网站建设 2026/5/26 5:16:42

前端开发:提示词驱动的全链路

2025 前端开发大变局&#xff1a;从“手写代码”到“提示词驱动”的全链路革命 引言&#xff1a;前端开发的新常态 在 2025 年&#xff0c;如果你还在逐行敲入 <div> 和 handleOnClick&#xff0c;那么你可能正在掉队。前端领域已经进入了**“提示词即开发” (Prompt-a…

作者头像 李华
网站建设 2026/5/25 23:12:10

影刀RPA实战:3步搞定希音客户行为数据提取,效率飙升[特殊字符]

影刀RPA实战&#xff1a;3步搞定希音客户行为数据提取&#xff0c;效率飙升&#x1f680;每天手动整理希音数据浪费3小时&#xff1f;别让低效重复工作偷走你的创作时间&#xff01;今天分享如何用影刀RPA打造智能数据提取机器人&#xff0c;原需半天的任务现在3分钟自动完成—…

作者头像 李华
网站建设 2026/5/25 21:14:28

CTF中Web题目的常见题型及解题姿势,零基础入门到精通,收藏这篇就够了

一、基础知识类题目 考察基本的查看网页源代码、HTTP请求、修改页面元素等。 这些题很简单&#xff0c;比较难的比赛应该不会单独出&#xff0c;就算有应该也是Web的签到题。 实际做题的时候基本都是和其他更复杂的知识结合起来出现。 姿势&#xff1a;恶补基础知识就行 查…

作者头像 李华