freemarker写select组件(二十二)
一,讲解一
1、宏定义
- <#macro select id datas>
- <select id="${id}" name="${id}">
- <option>---请选择---</option>
- <#list datas as data>
- <option value="${data}">${data}</option>
- </#list>
- </select>
- </#macro>
2、示例引入
- <#import "/inc/select.ftl" as items/>
- <@items.select id="city" datas=["武汉市","黄石市","黄冈市","荆州市"]/>
3、示例结果
(1)控制台打印结果
- <select id="city" name="city">
- <option>---请选择---</option>
- <option value="武汉市">武汉市</option>
- <option value="黄石市">黄石市</option>
- <option value="黄冈市">黄冈市</option>
- <option value="荆州市">荆州市</option>
- </select>
(2)页面显示结果
二,讲解二
1、宏定义
- <#macro select id datas value="">
- <select id="${id}" name="${id}">
- <option>---请选择---</option>
- <#list datas as data>
- <#if value == data>
- <option value="${data}" selected>${data}</option>
- <#else>
- <option value="${data}">${data}</option>
- </#if>
- </#list>
- </select>
- </#macro>
2、页面引入
- <@items.select id="zhuanye" datas=["请选择专业","计算机科学与技术","物流工程","英语专业"] value="计算机科学与技术"/>
3、运行结果
(1)控制台
- <select id="zhuanye" name="zhuanye">
- <option>---请选择---</option>
- <option value="请选择专业">请选择专业</option>
- <option value="计算机科学与技术" selected>计算机科学与技术</option>
- <option value="物流工程">物流工程</option>
- <option value="英语专业">英语专业</option>
- </select>
(2)页面显示
三,讲解三
1、宏定义
- <#macro select id datas value="" key="" text="">
- <select id="${id}" name="${id}">
- <option>---请选择---</option>
- <#list datas as data>
- <#if key!="">
- <#if value == data[key]?string>
- <option value="${data[key]}" selected>${data[text]}</option>
- <#else>
- <option value="${data[key]}">${data[text]}</option>
- </#if>
- <#else>
- <#if value == data>
- <option value="${data}" selected>${data}</option>
- <#else>
- <option value="${data}">${data}</option>
- </#if>
- </#if>
- </#list>
- </select>
- </#macro>
2、封装类
- /**
- * @Title:User.java
- * @Package:com.you.freemarker.model
- * @Description:
- * @author:Youhaidong(游海东)
- * @date:2014-6-26 下午10:28:01
- * @version V1.0
- */
- package com.you.freemarker.model;
- /**
- * 类功能说明
- * 类修改者 修改日期
- * 修改说明
- * <p>Title:User.java</p>
- * <p>Description:游海东个人开发</p>
- * <p>Copyright:Copyright(c)2013</p>
- * @author:游海东
- * @date:2014-6-26 下午10:28:01
- * @version V1.0
- */
- public class User
- {
- /**
- * 用户号
- */
- private int userNo;
- /**
- * 用户姓名
- */
- private String userName;
- /**
- * 用户年龄
- */
- private int userAge;
- /**
- * @return the userNo
- */
- public int getUserNo() {
- return userNo;
- }
- /**
- * @param userNo the userNo to set
- */
- public void setUserNo(int userNo) {
- this.userNo = userNo;
- }
- /**
- * @return the userName
- */
- public String getUserName() {
- return userName;
- }
- /**
- * @param userName the userName to set
- */
- public void setUserName(String userName) {
- this.userName = userName;
- }
- /**
- * @return the userAge
- */
- public int getUserAge() {
- return userAge;
- }
- /**
- * @param userAge the userAge to set
- */
- public void setUserAge(int userAge) {
- this.userAge = userAge;
- }
- /**
- * <p>Title:</p>
- * <p>Description:</p>
- * @param userNo
- * @param userName
- * @param userAge
- */
- public User(int userNo, String userName, int userAge) {
- super();
- this.userNo = userNo;
- this.userName = userName;
- this.userAge = userAge;
- }
- /**
- * <p>Title:</p>
- * <p>Description:</p>
- */
- public User() {
- super();
- }
- }
3、页面引入
- <@items.select id="user" datas=users key="userNo" text="userName"/>
4、Junit测试方法
- /**
- *
- * @Title:testSelect
- * @Description:
- * @param:
- * @return: void
- * @throws
- */
- @Test
- public void testSelect()
- {
- List<User> users = Arrays.asList(new User(1,"张三丰",25),
- new User(2,"李思思",22),
- new User(3,"赵武",23),
- new User(4,"刘雪",20),
- new User(5,"朱顾",21),
- new User(6,"赵武",23),
- new User(7,"吴语",24),
- new User(8,"血玉",21));
- root.put("users", users);
- studentPrint("address.ftl");
- studentFile("address.ftl","address.html");
- }
5、测试结果
(1)控制台打印
- <select id="user" name="user">
- <option>---请选择---</option>
- <option value="1">张三丰</option>
- <option value="2">李思思</option>
- <option value="3">赵武</option>
- <option value="4">刘雪</option>
- <option value="5">朱顾</option>
- <option value="6">赵武</option>
- <option value="7">吴语</option>
- <option value="8">血玉</option>
- </select>
(2)页面显示
四,讲解四
1、宏定义
- <#macro select id datas value="" key="" text="" headKey="" headValue="">
- <select id="${id}" name="${id}">
- <option>---请选择---</option>
- <#if headKey!="">
- <option value="${headKey}">${headValue}</option>
- </#if>
- <#list datas as data>
- <#if key!="">
- <#if value == data[key]?string>
- <option value="${data[key]}" selected>${data[text]}</option>
- <#else>
- <option value="${data[key]}">${data[text]}</option>
- </#if>
- <#else>
- <#if value == data>
- <option value="${data}" selected>${data}</option>
- <#else>
- <option value="${data}">${data}</option>
- </#if>
- </#if>
- </#list>
- </select>
- </#macro>
2、引入宏
- <@items.select id="username" datas=users key="userNo" text="userName" headKey="0" headValue="其他"/>
3、示例结果
- <select id="username" name="username">
- <option>---请选择---</option>
- <option value="0">其他</option>
- <option value="1">张三丰</option>
- <option value="2">李思思</option>
- <option value="3">赵武</option>
- <option value="4">刘雪</option>
- <option value="5">朱顾</option>
- <option value="6">赵武</option>
- <option value="7">吴语</option>
- <option value="8">血玉</option>
- </select>
五,讲解五
1、宏定义
- <#macro select id datas value="" key="" text="" headKey="" headValue="">
- <select id="${id}" name="${id}">
- <option>---请选择---</option>
- <#if headKey!="">
- <option value="${headKey}">${headValue}</option>
- </#if>
- <#if datas?is_hash_ex>
- <#local keys=datas?keys/>
- <#list keys as key>
- <#if key==value>
- <option value="${key}" selected>${datas[key]}</option>
- <#else>
- <option value="${key}">${datas[key]}</option>
- </#if>
- </#list>
- <#else>
- <#list datas as data>
- <#if key!="">
- <#if value == data[key]?string>
- <option value="${data[key]}" selected>${data[text]}</option>
- <#else>
- <option value="${data[key]}">${data[text]}</option>
- </#if>
- <#else>
- <#if value == data>
- <option value="${data}" selected>${data}</option>
- <#else>
- <option value="${data}">${data}</option>
- </#if>
- </#if>
- </#list>
- </#if>
- </select>
- </#macro>
2、宏引入
- <@items.select id="sex" datas={"0":"请选择学历","1":"小学","2":"初中","3":"高中","4":"本科"} />
3、运行结果
- <select id="sex" name="sex">
- <option>---请选择---</option>
- <option value="0">请选择学历</option>
- <option value="1">小学</option>
- <option value="2">初中</option>
- <option value="3">高中</option>
- <option value="4">本科</option>
- </select>
freemarker写select组件(二十二)的更多相关文章
- freemarker写select组件(二)
freemarker写select组件 1.宏定义 <#macro select id datas value=""> <select id="${id ...
- freemarker写select组件(一)
freemarker写select组件 1.宏定义 <#macro select id datas> <select id="${id}" name=" ...
- freemarker写select组件(五)
freemarker写select组件 1.宏定义 <#macro select id datas value="" key="" text=" ...
- freemarker写select组件(四)
freemarker写select组件 1.宏定义 <#macro select id datas value="" key="" text=" ...
- freemarker写select组件(三)
freemarker写select组件 1.宏定义 <#macro select id datas value="" key="" text=" ...
- freemarker写select组件报错总结(一)
1.具体错误如下 六月 25, 2014 11:26:29 下午 freemarker.log.JDK14LoggerFactory$JDK14Logger error 严重: Template pr ...
- freemarker写select组件报错总结(二)
1.错误描述 六月 25, 2014 11:32:49 下午 freemarker.log.JDK14LoggerFactory$JDK14Logger error 严重: Template proc ...
- freemarker写select组件报错总结(七)
1.错误描述 六月 26, 2014 11:26:27 下午 freemarker.log.JDK14LoggerFactory$JDK14Logger error 严重: Template proc ...
- freemarker写select组件报错总结(六)
1.错误描述 六月 26, 2014 10:53:26 下午 freemarker.log.JDK14LoggerFactory$JDK14Logger error 严重: Template proc ...
随机推荐
- IDEA如何创建及配置Web项目(多图)
正文之前 在学习Java Web时,第一个遇到的问题就是如何创建或配置Web项目了,今天,就用IntelliJ IDEA 来进行Web项目配置: 创建Web项目 配置web项目 正文 创建Web项目 ...
- Google chrome浏览器中通过扩展调用本地应用程序以及和程序相互通讯(C++)
最近项目用到浏览插件的开发,IE用到的是BHO,chrome打算做成扩展. 但是和ie有一点不同,chrome扩展是基于html+js+css开发的,那么就会有二个问题 1. 代码和算法等容易被别人复 ...
- VS2010+opencv2.4.10+gsl_1.8配置实现RobHess的SIFT程序
最近在做sift方面的毕业设计,弄了一天终于把RobHess的SIFT程序调通了.虽然网上有很多相关博文,但是我还是想把我的调试的过程跟大家分享一下.由于工程没法在博文上传,所以有需要的可以在下方留言 ...
- 安装gitlab8.0在reconfigure报错
现象: https://gitlab.com/gitlab-org/omnibus-gitlab/issues/303 参考方法: https://forum.gitlab.com/t/gitlab- ...
- mac攻略(2) -- apache站点配置
[http://www.cnblogs.com/redirect/p/6112164.html] Mac OS X 中默认有两个目录可以直接运行你的 Web 程序, 一个是系统级的 Web 根目录:/ ...
- MySQL中order by排序时,数据存在null咋办
order by排序是最常用的功能,但是排序有时会遇到数据为空null的情况,这样排序就会乱了,这里以MySQL为例,记录我遇到的问题和解决思路. 问题: 网页要实现table的行鼠标拖拽排序,我用A ...
- python多版本以及各种包管理
python多版本以及各种包管理 python 包管理 各个版本 python版本管理 由于Python有2.x和3.x两个大的版本,而且每一个工程建立所用的各种包的版本也不尽相同(如flask1.x ...
- Flask從入門到入土(二)——請求响应與Flask扩展
———————————————————————————————————————————————————————————— 一.程序和請求上下文 Flask從客戶端收到請求時,要讓視圖函數能訪問一些對象 ...
- CodeForces - 796D Police Stations bfs
思路:删除尽量多的边使得所有点都能在限制距离之内到达一个警局,删除边会形成多棵子树,最多只能k棵.其实就是以每个警局为根结点,把整棵树划分为以警局为根结点的k棵树,说明要删除的边的数量就是k-1条,即 ...
- UESTC 251 最长上升子序列O(nlgn)
O(n^2)过不了.必须要用一个额外的数组保存当前长度最小值,然后lgn查表 AC代码 #include<cstdio> #include<algorithm> using n ...