10.Web组件复用
1.静态包含(一个指令)
在软件工程中构建可复用组件可极大的提高软件生产效率、增强系统的可维护性
HTML标记对于一个web应用系统中的页面都是通用的,比如公司标志、版权声明、导航菜单
JSP中引用的web组件复用的两种方式:静态包含、动态包含。
在JSP源文件转换成对应Servlet源文件时将当前JSP文件和其包含的所有其他文件合并成一个Servlet文件
JSP中的include伪指令实现静态包含
include标准语法:<%@include file=“地址”%>
包含文件中要避免使用<html><body>等可能会影响原JSP网页中标签的元素
<%@include %>指令只有一个属性file
<%@include%>指令可以放在JSP页面的任意位置,其file所指的路径是相对路径
静态包含规则:
1.file属性值不能是一个动态表达式
错误示例:<% String myUrl=“copy.html” %><%@ include file=“<%=myUrl%>” %>
2.
错误示例:<%@ include file=“other.jsp?abc=qwe”%>
由于被包含文件之间可以共享变量,尽量减少文件之间的联系,降低耦合度,增强可复用度
2.动态包含
动态包含是指客户端请求时,将请求转发给当前JSP文件包含的其他对象
使用JSP的include动作指令和forward动作指令实现动态包含
include 和forward相当与Servlet中的RequestDispatcher.include()和RequestDispatcher.forward()方法
include动作指令:
include允许当前页面将客户端请求暂时转交给所包含的对象,一旦对象执行完毕,返回当前JSP页面
include动作指令相当于方法的调用
标准语法:<jsp:include page=“地址” flush=“true”>
动态包含作用域范围:
动态包含中的包含文件和被包含文件各自独立编译、执行,彼此之间不能访问各自定义的变量(即page作用域范围内的对象),只能共享request范围、session范围、application范围对象
include 动作指令规则:
page属性值可以是相对路径或代表相对路径的表达式;
page属性指向的文件既可以是动态文件也可以是静态文件
两种包含的比较:
include伪指令 |
include动作指令 |
|
规则 |
<%@include %> |
<jsp:include /> |
编译时间 |
较慢(资源必须被解析) |
较快 |
执行时间 |
较快 |
较慢(因为每次请求资源必须被解析) |
灵活性 |
较差(页面内容必须固定) |
较好(页面在运行时可动态选择) |
动作发生的时间 |
页面转换期间 |
请求期间 |
被包含的内容 |
文件的内容 |
页面的输出 |
产生Servlet数目 |
1 |
n |
变静态包含被包含页面可以访问包含页面中的变量
静态包含所包含的文件能够含有影响整个页面的JSP内容(如:import语句,声明)
参数的传递:
静态包含不存在参数传递的问题
动态包含可以传递参数:
直接在包含动作中传递
使用<jsp:param>
使用request.set/getAttribute()方法
使用注意事项:
静态包含:
被包含页面中的指令不能与包含页面中有冲突(要注意变量多次声明问题)
动态包含:
使用XML格式,不要忘记标签封口
forward动作指令:
forward动作指令允许将客户请求转发到另一个资源文件,即每当遇到此动作指令就停止执行当前的JSP,转而执行被转发的指定资源
语法格式:<jsp:forward page=“地址”/>
page属性必须存在,用于指定要包含的静态或动态文件,可以是字符串或表达式
forward指令与include动作指令
forward动作指令在调用转发操作后不会继续处理指令后的任何代码
include动作指令在调用转发操作后,完成转发操作后将继续处理指令后的代码
动态指令的参数传递:
使用<jsp:param name=“” value=“”/>可以传递一个或多个参数给动态页面
与include动作指令、forward动作指令一起使用
注意:<jsp:param />标签传递参数时,会替换request对象同名的参数值
3.使用JavaBean组件;
概述:
JavaBean通过封装属性和方法成为具有某种功能或者处理某个业务的对象,简称Bean
JavaBean中所有的属性最好定义为private,每个属性都定义public的setter和getter方法对其进行操作
JavaBean命名规则:
JSP使用JavaBean:
在JSP中使用<jsp:useBean>操作元素来加载JavaBean程序
使用<jsp:setProperty>操作元素来设置JavaBean的属性值
使用<jsp:getProperty>操作元素获取JavaBean的属性值
useBean动作指令:
属性 |
功能描述 |
示例 |
id |
使用此变量名来分辨不同的Bean |
id=“address” |
scope |
JavaBean存在的范围(作用域范围) |
scope=“session” |
class |
JavaBean对应的类名 |
class=“AddressBean” |
type |
引用JavaBean变量的类型 |
type=“AddressBean” |
beanName |
装载序列化JavaBean名或创建实例类名,使用java.beans.Beans.instantiate方法 |
beanName=“AddressBean” |
setProperty动作指令:
属性 |
功能描述 |
name |
JSP页面中的JavaBean标识名称 |
property |
JavaBean的属性名称 |
value |
被赋予JavaBean属性的新值 |
param |
HttpServletRequest的参数(参数名称与JavaBean名称不相同时需要设置) |
getProperty()动作指令:
属性 |
功能描述 |
name |
JSP页面中的JavaBean标识名称 |
property |
JavaBean的属性名称 |
10.Web组件复用的更多相关文章
- Svelte入门——Web Components实现跨框架组件复用
Svelte 是构建 Web 应用程序的一种新方法,推出后一直不温不火,没有继Angular.React和VUE成为第四大框架,但也没有失去热度,无人问津.造成这种情况很重要的一个原因是,Svelte ...
- 探讨Web组件化的实现
CMS组件化,简单架构示意图: Web组件使用WebPage+WebAPI的好处: Ø 组件复用(组件条件管理页面复用+获取组件数据API复用). Ø 组件是分布式的第三方应用,本身高内聚.组件之 ...
- [阿当视频]WEB组件学习笔记
— 视频看完了,自定义事件还不懂,等完全懂了再更新并完成整篇案例 1. JS分层和组件的种类浏览器底层包括HTML CSS JS(DOM/BOM/Style/Canvas 2D/WebGl/SVG) ...
- 前端UI组件复用工具
"懒"是第一生产力. 代码复用总是程序员喜闻乐见的,前端组件化的最终目的就是复用,今天我们就将深入探讨如何实现UI组件的复用. 通常我们所说的组件往往是包含业务逻辑的前端组件,而这 ...
- Amaze UI 发布基于jQuery新版本v2.0.0之web组件
首先Amaze Ui第一版时我收到邮件邀请去试用,去了官网看了下,是基于zepto.js的一个类似bootstrap的响应式框架,提到框架当然是好事,快速开发呗.这词2.0的弃用zepto.js改用j ...
- atitit. web组件化原理与设计
atitit. web组件化原理与设计 1. Web Components提供了一种组件化的推荐方式,具体来说,就是:1 2. 组件化的本质目的并不一定是要为了可复用,而是提升可维护性. 不具有复用 ...
- atitit.atiHtmlUi web组件化方案与规范v1
atitit.atiHtmlUi web组件化方案与规范v1 1. 如何在现有html 标签基础上定义自己的组件1 2. 组件的构成与定义1 3. 组件的加载1 4. 组件css的加载2 5. 操作组 ...
- SpringMVC内容略多 有用 熟悉基于JSP和Servlet的Java Web开发,对Servlet和JSP的工作原理和生命周期有深入了解,熟练的使用JSTL和EL编写无脚本动态页面,有使用监听器、过滤器等Web组件以及MVC架构模式进行Java Web项目开发的经验。
熟悉基于JSP和Servlet的Java Web开发,对Servlet和JSP的工作原理和生命周期有深入了解,熟练的使用JSTL和EL编写无脚本动态页面,有使用监听器.过滤器等Web组件以及MVC架构 ...
- 【收藏】这么多WEB组件(CSS),攒一个网站够了吧?
简言 总是喜欢简单又精致的东西,美的不繁复也不张扬.这是闷骚程序员的癖好么?闲来无事,把收集到的部分WEB组件整理汇总一下,攒一个逼格高一点的网站够了吧? 1 表单(form)相关 1.1 输入框(i ...
随机推荐
- springboot启动过程(2)-run方法
1 springApplication的run run方法主要是用于创造spring容器ConfigurableApplicationContext对象. public ConfigurableApp ...
- Codeforces Good Bye 2018 D (1091D) New Year and the Permutation Concatenation
题意:给n!个n的排列,按字典序从小到大连成一条序列,例如3的情况为:[1,2,3, 1,3,2, 2,1,3 ,2,3,1 ,3,1,2 ,3,2,1],问其中长度为n,且和为sum=n*(n+1) ...
- setjmp和longjmp
此文是学习 C专家编程 中的笔记. setjmp和longjmp是C语言所独有的,它们部分弥补了C语言有限的转移能力. 函数说明(来自wiki百科): int setjmp(jmp_buf env) ...
- ZROI2018普转提day6t1
传送门 分析 记录区间最大值,线段树上二分找比这个点大的最靠前位置即可 代码 #include<iostream> #include<cstdio> #include<c ...
- Luogu 1641 [SCOI2010]生成字符串
结果和dp没有一点关系…… 30分算法:设$f_{i, j}$表示已经选了$i$个并且有$j$个是白色的状态数,转移显然,最后答案就是$f_{n + m, m}$,时间复杂度$O(n^{2})$. 1 ...
- MATLAB数字图像处理(二)图像增强
1 图像增强 1.1 直方图均衡化 对于灰度图像,可以使用直方图均衡化的方法使得原图像的灰度直方图修正为均匀的直方图. 代码如下: I2=histeq(I1); ...
- Java50道经典习题-程序28 排序算法
题目:对10个数进行排序分析:可以利用选择法,即从后9个比较过程中,选择一个最小的与第一个元素交换, 下次类推,即用第二个元素与后8个进行比较,并进行交换. public class Prog28 { ...
- c#设计模式-单例模式【转】
单例模式三种写法: 第一种最简单,但没有考虑线程安全,在多线程时可能会出问题 public class Singleton { private static Singleton _instance = ...
- yum源安装Percona
yum源安装更为简单,方便.话不多说,开始吧. 1.下载yum源 yum -y install https://www.percona.com/redir/downloads/percona-rele ...
- Scrapy 中 Request 对象和 Response 对象的各参数及属性介绍
Request 对象 Request构造器方法的参数列表: Request(url [, callback=None, method='GET', headers=None, body=None,co ...