JSTL <c:import> 标签详解与EL表达式应用
需积分: 9 118 浏览量
更新于2024-08-18
收藏 3.74MB PPT 举报
"<c:import>标记用于在JSP页面中包含其他静态或动态文件,不仅限于同一web应用,还可以跨应用甚至引用外部网站内容。它与<jsp:include>的主要区别在于包含范围的不同。<c:import>提供两个语法形式,允许设置变量和字符编码,并通过EL表达式来灵活地访问数据。
EL(Expression Language)是JSTL的一部分,自JSP2.0开始成为标准规范,使得在JSP页面中更便捷地存取数据。EL的语法以${}包裹,如${sessionScope.user.sex}表示从Session范围获取用户性别。EL提供了.和[]两种运算符,用于访问对象属性。当属性名包含特殊字符或者需要动态取值时,应使用[]运算符。例如,${user["My-Name"]}用于访问属性名为"My-Name"的对象字段,而${sessionScope.user[data]}则根据变量data的值动态访问user对象的属性。
在使用EL时,.和[]可以混合使用,如${sessionScope.shoppingCart[0].price},这表示获取购物车第一个商品的价格。当使用[]时,如果expr-a为null,则返回null;如果expr-b为null且expr-a为Map类型,也会返回null。如果expr-a是一个Map,那么expr-b的值将作为键来查找Map中的值。
<c:import>标记的完整语法包括以下几个属性:
- url:必需,指定要导入的URL。
- context:可选,提供额外的上下文路径。
- var:可选,将导入的内容存储为一个变量。
- scope:可选,指定变量的作用域,可选值为page、request、session或application。
- charEncoding:可选,设置字符编码。
总结来说,<c:import>是JSP页面中强大的包含工具,结合EL表达式,能够灵活地处理数据和导入各种资源,提升开发效率和代码的可读性。"
2007-07-13 上传
2021-01-16 上传
2021-11-22 上传
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import="java.util.*,edu.nustti.dao.*,edu.nustti.dao.impl.*" %> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>用户注册</title> </head> <body> <form action="/STU_manager/servlet/UserServlet?action=register" name="f1" method="post">
用户名: | <input type="text" name="userName"> |
密 码: | <input type="password" name="password"> |
姓 名: | <input type="text" name="trueName"> |
性 别: | <input type="radio" checked="checked" name="sex" value="0">男 <input type="radio" name="sex" value="1">女 |
生 日: | <select name="y"> <c:forEach begin="1990" end="2010" var="y"> <option value="${y}">${y}</option> </c:forEach> </select> <select name="m"> <c:forEach begin="1" end="9" var="m"> <option value="0${m}">${m}</option> </c:forEach> <c:forEach begin="10" end="12" var="m"> <option value="${m}">${m}</option> </c:forEach> </select> <select name="d"> <c:forEach begin="1" end="9" var="d"> <option value="0${d}">${d}</option> </c:forEach> <c:forEach begin="10" end="31" var="d"> <option value="${d}">${d}</option> </c:forEach> </select> |
爱 好: | <% FavoritesDao dao1 = new FavoritesDaolmp1(); // 创建爱好存储业务模型 List list1 = dao1.getAllFavorates(); request.setAttribute("F", list1); %> <c:forEach var="f" items="${F}"> <input type="checkbox" name="favorates" value="${f.id }">${f.favorate} </c:forEach> |
班 级: | <% ClassesDao dao2 =(ClassesDao) new ClassesDaoImpl(); // 创建班级存储业务模型 List list2 = dao2.getAllClasses(); request.setAttribute("C", list2); %><select name="classId"> <c:forEach var="c" items="${C}"> <option value="${c.id}">${c.className}</option> </c:forEach> </select> |
介 绍: | <textarea rows="10" cols="20" name="introduction"></textarea> |
<input type="submit" value="注册"> |
2023-05-19 上传
2023-05-30 上传
点击了解资源详情
点击了解资源详情
2023-07-23 上传
2024-10-20 上传
花香九月
- 粉丝: 26
- 资源: 2万+
最新资源
- C++ Qt影院票务系统源码发布,代码稳定,高分毕业设计首选
- 纯CSS3实现逼真火焰手提灯动画效果
- Java编程基础课后练习答案解析
- typescript-atomizer: Atom 插件实现 TypeScript 语言与工具支持
- 51单片机项目源码分享:课程设计与毕设实践
- Qt画图程序实战:多文档与单文档示例解析
- 全屏H5圆圈缩放矩阵动画背景特效实现
- C#实现的手机触摸板服务端应用
- 数据结构与算法学习资源压缩包介绍
- stream-notifier: 简化Node.js流错误与成功通知方案
- 网页表格选择导出Excel的jQuery实例教程
- Prj19购物车系统项目压缩包解析
- 数据结构与算法学习实践指南
- Qt5实现A*寻路算法:结合C++和GUI
- terser-brunch:现代JavaScript文件压缩工具
- 掌握Power BI导出明细数据的操作指南