Java开发之JSP行为

一、Java Bean行文

1.重点说明

      Java Bean行为是一组与Java Bean相关的行为,包括useBean行为、setProperty行为、getProperty行为等。Java Bean就是普通的Java类。Java Bean类非常简单,只有私有属性与对应的getter方法和setter方法。(注意:对于boolean类型的属性,习惯上一般把getter方法写成isXxx(),而不是getXxx())

useBean行为属性
    属性名         取值范围描述
id      合法的Java变量名

指明Java Bean对象的名称。

JSP中可以使用该名称引用该Java Bean对象。

class        Java Bean类的全名Java Bean类的全名。
scope          

page,

request,

session,

application

该Java Bean对象的范围。

当为page时,只在该JSP内有效。

当为request时,只在当前的request中有效。

当为session时,对当前用户有效。

当为application时,当前Web应用程序内有效。默认为page。

 


2.代码实践
 

scope实现各种计数器

Counter.java

 

 1 package com.bean;
 2 
 3 public class Counter {
 4 
 5     private int count;         //计数器
 6     
 7     public int getCount(){       //每访问一次,计数器自加1
 8         return ++count;
 9     }
10     public void setCount(int count){
11         this.count = count;
12     }
13 }

 

Counter.jsp

 1 <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
 2 <%
 3 String path = request.getContextPath();
 4 String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
 5 %>
 6 
 7 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
 8 <html>
 9   <head>
10     <base href="<%=basePath%>">
11     
12     <title>My JSP 'Counter.jsp' starting page</title>
13     
14     <meta http-equiv="pragma" content="no-cache">
15     <meta http-equiv="cache-control" content="no-cache">
16     <meta http-equiv="expires" content="0">    
17     <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
18     <meta http-equiv="description" content="This is my page">
19     <!--
20     <link rel="stylesheet" type="text/css" href="styles.css">
21     -->
22 
23   </head>
24   
25   <body>
26     <!-- 定义一个session范围内的计数器,记录个人访问信息 -->
27     <jsp:useBean id="personCount" class="com.bean.Counter" scope="session" />
28     <!-- 定义一个application范围内的计数器,记录所有人的反问信息 -->
29     <jsp:useBean id="totalCount" class="com.bean.Counter" scope="application" />
30     <div align="center">
31         <form action="page/Counter.jsp" method="get">
32             <fieldset style="width:300">
33                <legend>计数器</legend>
34                <table align="center" width="400">
35                <tr>
36                    <td>您的访问次数:
37                    </td>
38                    <td>
39                        <!-- 获取个人的访问次数 -->
40                        <jsp:getProperty property="count" name="personCount"/>
41                    </td>
42                </tr>
43                <tr>
44                    <td>总共的访问次数:
45                    </td>
46                    <td>
47                        <!-- 获取所有人的访问次数 -->
48                        <jsp:getProperty property="count" name="totalCount"/>
49                    </td>
50                </tr>
51                <tr>
52                    <td colspan="2">
53                       <input type="submit" value="刷新">
54                    </td>
55                </tr>
56                </table>
57             </fieldset>
58         </form>
59     </div>
60   </body>
61 </html>

3.效果截图

二、<jsp:plugin/>嵌入Applet

1.重点说明

    Java Applet是运行在客户端浏览器里的Java小程序。JSP提供了一组plugin行为简化嵌入Applet的操作。plugin行为包括<jsp:plugin/><jsp:params/><jsp:param/><jsp:fallback/>。其中<jsp:plugin/>用于在JSP中定义Java Applet,并声明Applet的宽度和高度等属性;<jsp:params/>用于定义一组一对多的参数;<jsp:param/>用于定义单个的参数;<jsp:fallback/>用于定义不支持Applet时的替代信息。

2.程序实践

Plugin.jsp

 1 <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
 2 <%
 3 String path = request.getContextPath();
 4 String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
 5 %>
 6 
 7 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
 8 <html>
 9   <head>
10     <base href="<%=basePath%>">
11     
12     <title>My JSP 'Plugin.jsp' starting page</title>
13     
14     <meta http-equiv="pragma" content="no-cache">
15     <meta http-equiv="cache-control" content="no-cache">
16     <meta http-equiv="expires" content="0">    
17     <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
18     <meta http-equiv="description" content="This is my page">
19     <!--
20     <link rel="stylesheet" type="text/css" href="styles.css">
21     -->
22 
23   </head>
24   
25   <body>
26     <table align="center" bgcolor="#999999" cellpadding="1">
27        <tr>
28           <td bgcolor="#FFFFFF">
29               <jsp:plugin 
30                    code="Graph.class" 
31                    codebase="http://java.sun.com/applets/jdk/1.4/demo/applets/GraphLayout/" 
32                    type="applet" width="500" height="400">
33                    <jsp:params>
34                       <jsp:param value="joe-food,joe-dog,joe-tea,table-plate/50"
35                        name="edges"/>
36                    </jsp:params>
37                    <jsp:fallback>您的浏览器不支持Java Applet</jsp:fallback>
38               </jsp:plugin>
39               
40           </td>
41        </tr>
42     </table>
43   </body>
44 </html>

3.效果截图

这里不知道怎么被阻止了。

 

三、<jsp:directive/>行为

      <jsp:directice/>行为相当于JSP指令。<jsp:directive.page/>行为相当于<%@ page%>指令,<jsp:directive.include/>行为相当于<%@ include%>指令,<jsp:directive.taglib/>行为相当于<%@ taglib%>指令。

      注意:现在的Java Web开发平台更倾向于使用directive行为而不使用JSP指令。这是因为<jsp:directive/>行为比JSP指令更整洁,可读性更好。

 

转载于:https://www.cnblogs.com/landiljy/p/5773590.html

下载前可以先看下教程 https://pan.quark.cn/s/a4b39357ea24 在网页构建过程中,表单(Form)扮演着用户与网站之间沟通的关键角色,其主要功能在于汇集用户的各类输入信息。 JavaScript作为网页开发的核心技术,提供了多样化的API和函数来操作表单组件,诸如input和select等元素。 本专题将详细研究如何借助原生JavaScript对form表单进行视觉优化,并对input输入框与select下拉框进行功能增强。 一、表单基础1. 表单组件:在HTML语言中,<form>标签用于构建一个表单,该标签内部可以容纳多种表单组件,包括<input>(输入框)、<select>(下拉框)、<textarea>(多行文本输入区域)等。 2. 表单参数:诸如action(表单提交的地址)、method(表单提交的协议,为GET或POST)等属性,它们决定了表单的行为特性。 3. 表单行为:诸如onsubmit(表单提交时触发的动作)、onchange(表单元素值变更时触发的动作)等事件,能够通过JavaScript进行响应式处理。 二、input元素视觉优化1. CSS定制:通过设定input元素的CSS属性,例如border(边框)、background-color(背景色)、padding(内边距)、font-size(字体大小)等,能够调整其视觉表现。 2. placeholder特性:提供预填的提示文字,以帮助用户明确输入框的预期用途。 3. 图标集成:借助:before和:after伪元素或者额外的HTML组件结合CSS定位技术,可以在输入框中嵌入图标,从而增强视觉吸引力。 三、select下拉框视觉优化1. 复选功能:通过设置multiple属性...
【EI复现】基于深度强化学习的微能源网能量管理与优化策略研究(Python代码实现)内容概要:本文围绕“基于深度强化学习的微能源网能量管理与优化策略”展开研究,重点探讨了如何利用深度强化学习技术对微能源系统进行高效的能量管理与优化调度。文中结合Python代码实现,复现了EI级别研究成果,涵盖了微电网中分布式能源、储能系统及负荷的协调优化问题,通过构建合理的奖励函数与状态空间模型,实现对复杂能源系统的智能决策支持。研究体现了深度强化学习在应对不确定性可再生能源出力、负荷波动等挑战中的优势,提升了系统运行的经济性与稳定性。; 适合人群:具备一定Python编程基础和机器学习背景,从事能源系统优化、智能电网、强化学习应用等相关领域的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于微能源网的能量调度与优化控制,提升系统能效与经济效益;②为深度强化学习在能源管理领域的落地提供可复现的技术路径与代码参考;③服务于学术研究与论文复现,特别是EI/SCI级别高水平论文的仿真实验部分。; 阅读建议:建议读者结合提供的Python代码进行实践操作,深入理解深度强化学习算法在能源系统建模中的具体应用,重点关注状态设计、动作空间定义与奖励函数构造等关键环节,并可进一步扩展至多智能体强化学习或与其他优化算法的融合研究。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值