struts2 学习笔记

本文详细介绍了Struts2框架中的各种表单标签用法,包括文本框、密码框、单选按钮、复选框等,并展示了如何利用这些标签快速生成动态网页表单。

.要在JSP中加入<%@ taglib prefix="s" uri="/struts-tags" %> 才可以使用struts2标签,

1.文本框   <s:textfield name="loginName" label="loginName"></s:textfield>

生成HTML后为

<tr>
    <td class="tdLabel"><label for="checkLogin_loginName" class="label">loginName:</label></td>
    <td><input name="loginName" value="" id="checkLogin_loginName" type="text"></td>
</tr>

 生成的代码可以看出,name 不变,如果ID不指定的话,会生成ACTION_NAME 的形式的ID,建议人为指定相关的ID 这样可以方便后面的操作

2.密码框  <s:password name="pwd" label="password"></s:password>

  没什么说的,跟上面差不多。

3.单选按钮:radio 与checkboxlist 差不多

<!-- 使用字符串生成多个复选框  -->
        <s:radio 
            list="{'JSP','Servlet','Struts2.0','Ajax'}"
            name="skills"
            label="熟悉的技术"
            labelposition="top"
        >
        </s:radio>
        <!-- 使用MAP 对象来生成多个复选框 -->
        <s:radio
            list="#{'JSP':'JSP','Servlet':'Struts2.0','Struts2.0':'Struts2.0','Ajax':'Ajax'}"
            name="skillsarea"
            label="你所关注的技术领域"
            labelposition="top"
            listKey="key"
            listValue="value"
        >
        </s:radio>
        <!-- 使用JAVA 对象集合来生成多个复选框 -->
        <s:radio
            list="#bs.books"
            name="books"
            label="选择你喜欢的图书"
            labelposition="top"
            listKey="num"
            listValue="name"
        >
        </s:radio>
 4.checkboxlist 创建 多个复选框,
 list 属性指定集合来生成多个复选框,如果list是一个字符串集合就不用指定其他属性了
 如果是一个Map或者JAVA多个对象要指定listKey listValue两个属性了
 listKey该属性用来指定元素中的某个属性作为复选框的value 如果是MAP 则使用key
 listValue 该属性用来指定元素中某个属性作为复选框的标签 如果是Map 则使用value

    <!-- 使用字符串生成多个复选框  -->
        <s:checkboxlist
            list="{'JSP','Servlet','Struts2.0','Ajax'}"
            name="skills"
            label="熟悉的技术"
            labelposition="top"
        >
        </s:checkboxlist>
        <!-- 使用MAP 对象来生成多个复选框 -->
        <s:checkboxlist
            list="#{'JSP':'JSP','Servlet':'Struts2.0','Struts2.0':'Struts2.0','Ajax':'Ajax'}"
            name="skillsarea"
            label="你所关注的技术领域"
            labelposition="top"
            listKey="key"
            listValue="value"
        >
        </s:checkboxlist>
        <hr/>
        <!-- 使用JAVA 对象集合来生成多个复选框 -->
        <s:bean name="com.zjr.BookService" id="bs"></s:bean>
        <s:checkboxlist 
            list="#bs.books"
            name="books"
            label="选择你喜欢的图书"
            labelposition="top"
            listKey="num"
            listValue="name"
        >
        </s:checkboxlist>

 5.combobox

 
  <s:combobox
   label="图书列表"
   labelposition="top"
   list="{'JSP','Servlet','Struts2.0','Ajax'}"
   size="20"
   maxlength="20"
   name="books_1"
  >
  </s:combobox>
  <s:combobox
   label="图书列表"
   labelposition="top"
   list="#bs.books"
   size="20"
   maxlength="20"
   name="book_1"
   listKey="num"
   listValue="name"
  >
  </s:combobox>
 6.

<s:select
  list="{'JSP','Servlet1','Struts2.0','Ajax'}" 
    name="books11"
    label="图书列表"
  >
 </s:select> 
  <s:select name="books_selectmap" label="图书列表" labelposition="top"
  list="#{'JSP':'JSP','Servlet':'Struts2.0','Struts2.0':'Struts2.0','Ajax':'Ajax'}"
  listKey="key"
  listValue="value"
  ></s:select><br/><br/>
  <s:select
    label="图书列表"
   labelposition="top"
   list="#bs.books"
   name="book_select_java"
   listKey="num"
   listValue="name"
  ></s:select><br/><br/>
  7.doubleselect
 <!-- doubleselect必须指明form 的 action和 name ,否则出不来标签-->
   <s:set name="pc"
   value="#{'广西省':{'南宁','贵港','柳州'},'广东省':{'广州','深圳','珠海'}}"/>
  <s:doubleselect
   name="province" label="所在城市"
   list="#pc.keySet()" doubleName="city" doubleList="#pc[top]"
  ></s:doubleselect>
  <s:set name="foobar"
              value="#{'Java': {'Spring', 'Hibernate', 'Struts 2'},
              '.Net': {'Linq', ' ASP.NET 2.0'},'Database': {'Oracle', 'SQL Server', 'DB2', 'MySQL'}}" />
        <s:doubleselect list="#foobar.keySet()"
                          doubleName="technology"
                          doubleList="#foobar[top]"
                          label="Technology" />

 

8.optgroup标签
     <s:select label="您所关注的技术领域" name="skillsArea"
     list="#{'JavaScript':'JavaScript','ajax':'ajax','oracle':'oracle'}">
      <s:optgroup label="J2EE"
       list="#{'JSP':'JSP','Servlet':'Servlet','JavaBean':'JavaBean'}"
       listKey="value"
       listValue="key"
      ></s:optgroup>
      <s:optgroup label="JAVA开源框架"
       list="#{'Struts2':'Struts2','Hibernate3':'Hibernate3','Spring2':'Spring2'}"
       listKey="value"
       listValue="key"
      ></s:optgroup>
     </s:select>                  
   
   9.时间标签

 
    <s:datetimepicker name="birthday" label="出生日期" displayFormat="yyyy/MM/dd" />
    <s:datetimepicker name="recordtime" label="记录时间" type="time" language="en_US"></s:datetimepicker>

 

10.

<s:updownselect
     label="图书列表"
     list="{'struts2从入门到精通','Spring2开发宝典','Ajax实战'}"
     name="books_updownselect"
     headerKey="-1"
     headerValue="-----请选择-----"
     emptyOption="true"
     selectAllLabel="全选"
     moveUpLabel="上移"
     moveDownLabel="下移"
    />
   <s:updownselect
     label="您所关注的领域"
     list="#{'JAVA':'java','.NET':'.net','DATABASE':'database'}"
     name="skillarea"
     headerKey="-1"
     headerValue="-----请选择-----"
     emptyOption="true"
     selectAllLabel="全选"
     moveUpLabel="上移"
     moveDownLabel="下移"
   />
   <s:updownselect
     label="图书列表"
     list="#bs.books"
     listKey="name"
     listValue="name"
     name="skillarea_aba"
     headerKey="-1"
     headerValue="-----请选择-----"
     emptyOption="true"
     selectAllLabel="全选"
     moveUpLabel="上移"
     moveDownLabel="下移"
   />
  
   11.

 
   <s:optiontransferselect
     label="您目前已经掌握的技术"
     name="canSkills"
     leftTitle="技术信息列表"
     rightTitle="您的选择"
     list="{'struts2从入门到精通','Spring2开发宝典','Ajax实战'}"
     multiple="true"
     headerKey="-1"
  headerValue="---- 请选择 -----"
  emptyOption="true"
     doubleList=""
     doubleName="rightSideCartoonCharacters"
     doubleHeaderKey="doubleHeaderKey"
     doubleHeaderValue="---- 请选择 -----"
     doubleEmptyOption="true"
     doubleMultiple="true"
     addAllToLeftLabel="全部左移"
      addAllToRightLabel="全部右移"
      addToRightLabel="右移"
      addToLeftLabel="左移"
      selectAllLabel="全选"
      rightDownLabel="下称"
      rightUpLabel="上移"
      leftDownLabel="下称"
      leftUpLabel="上称"
     >
  
   </s:optiontransferselect>
                         
                         
  
   

欢迎使用“可调增益放大器 Multisim”设计资源包!本资源专为电子爱好者、学生以及工程师设计,旨在展示如何在著名的电路仿真软件Multisim环境下,实现一个具有创新性的数字控制增益放大器项目。 项目概述 在这个项目中,我们通过巧妙结合模拟电路与数字逻辑,设计出一款独特且实用的放大器。该放大器的特点在于其增益可以被精确调控,并非固定不变。用户可以通过控制键,轻松地改变放大器的增益状态,使其在1到8倍之间平滑切换。每一步增益的变化都直观地通过LED数码管显示出来,为观察和调试提供了极大的便利。 技术特点 数字控制: 使用数字输入来调整模拟放大器的增益,展示了数字信号对模拟电路控制的应用。 动态增益调整: 放大器支持8级增益调节(1x至8x),满足不同应用场景的需求。 可视化的增益指示: 利用LED数码管实时显示当前的放大倍数,增强项目的交互性和实用性。 Multisim仿真环境: 所有设计均在Multisim中完成,确保了设计的仿真准确性和学习的便捷性。 使用指南 软件准备: 确保您的计算机上已安装最新版本的Multisim软件。 打开项目: 导入提供的Multisim项目文件,开始查看或修改设计。 仿真体验: 在仿真模式下测试放大器的功能,观察增益变化及LED显示是否符合预期。 实验与调整: 根据需要调整电路参数以优化性能。 实物搭建 (选做): 参考设计图,在真实硬件上复现实验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值