1.写一个 Dao 层方法 查询数据方法要写成静态 以便直接调用
public static List<Category> findAllCategories() throws SQLException{ String sql = "select * from category"; QueryRunner qr = new QueryRunner(DataSourceUtils.getDataSource()); return qr.query(sql, new BeanListHandler<Category>(Category.class)); }
2.创建一个.tld 文件
<?xml version="1.0" encoding="UTF-8" ?> <taglib xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd" version="2.0"> <description>JSTL 1.1 functions library</description> <display-name>JSTL functions</display-name> <tlib-version>1.1</tlib-version> <short-name>myfn</short-name> <uri>http://www.zhangshaocui.cn</uri> <!-- 找不到文件时所访问的路径 --> <function> <description> Tests if an input string contains the specified substring. </description> <name>findAllCategories</name> <!-- 所调用的方法名 --> <function-class>com.yinhe.dao.CategoryDao</function-class> <!-- 所调用的方法的全路径 --> <function-signature>java.util.List findAllCategories()</function-signature> <!-- 返回值类型与方法名 --> </function> </taglib>
3.在前台用 c 标签 循环出来所有数据
<%@taglib prefix="myfn" uri="http://www.zhangshaocui.cn"%> <c:forEach var="category" items="${myfn:findAllCategories()}"> <a href="product_list.jsp">${category.cname}<span class="sr-only">(current)</span></a> </c:forEach>
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于