栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

JavaWeb.17.EL与JSTL的使用

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

JavaWeb.17.EL与JSTL的使用

在上一期讲了EL表达式和JSTL标签,这期来讲讲EL表达式与JSTL标签的用法,在了解EL表达式与JSTL标签后又可以将网页中的Java代码答题一部分,从而达到Java代码与网页代码进一步分离的效果,大大降低耦合性,下面直接开始上代码吧
IGoodsDao.java:

package com.zking.dao;
 
import java.util.List;
 
import com.zking.pojo.Goods;
 
public interface IGoodsDao {
 
	//查询所有
	List getAll(int page);
	//查询单个
	Goods getOne(Integer id);
	//查询所有页数
	int getRowCount(); 
 
}
 

GoodsDaoImpl.java:

package com.zking.dao.impl;
 
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
 
import com.zking.dao.IGoodsDao;
import com.zking.pojo.Goods;
import com.zking.pojo.User;
import com.zking.util.DBHelper;
 
public class GoodsDaolmpl implements IGoodsDao{
 
	
	private Connection con;
	private PreparedStatement ps;
	private ResultSet rs;
	
	@Override
	public List getAll(int page) {
		int size=5;//页面数据条数
		int begin=(page-1)*size+1;
		int end=page*size;
		List list = new ArrayList();
		try {
			con=DBHelper.getCon();
			String sql="select * from (select a.*,rownum myr from shop_goods a) b where myr between ? and ?";
			ps=con.prepareStatement(sql);
			ps.setInt(1,begin);
			ps.setInt(2,end);
			rs=ps.executeQuery();
			while(rs.next()) {
				Goods goods=new Goods();
				goods.setId(rs.getInt(1));
				goods.setName(rs.getString(2));
				goods.setPrice(rs.getInt(3));
				goods.setInfo(rs.getString(4));
				list.add(goods);
			}
			return list;
		} catch (Exception e) {
			e.printStackTrace();
		}finally {
			DBHelper.close(con, ps, rs);
		}
		return list;
  }
	 
	@Override
    public Goods getOne(Integer id) {
        try {
            con = DBHelper.getCon();
            ps = con.prepareStatement("select * from shop_goods where id=?");
            ps.setInt(1, id);
            rs = ps.executeQuery();
            if (rs.next()) {
                Goods goods = new Goods();
                goods.setId(rs.getInt(1));
                goods.setName(rs.getString(2));
                goods.setPrice(rs.getInt(3));
                goods.setInfo(rs.getString(4));
                return goods;
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            DBHelper.close(con, ps, rs);
        }
        return null;
    }
 
	@Override
	public int getRowCount() {
		   try {
	            con = DBHelper.getCon();
	            ps = con.prepareStatement("select count(1) from shop_goods");
	            rs = ps.executeQuery();
	            if(rs.next()) {
	            	return rs.getInt(1);
	            }
	        } catch (Exception e) {
	            e.printStackTrace();
	        } finally {
	            DBHelper.close(con, ps, rs);
	        }
		return 0;
	}
}

IGoodsBiz.java:

package com.zking.biz;
 
import java.util.List;
 
import com.zking.pojo.Goods;
 
public interface IGoodsBiz {
 
	List getAll(int page);
	//查询单个
	Goods getOne(Integer id);
	//查询所有页数
	int getRowCount(); 
}

GoodsBizImpl.java:

package com.zking.biz.impl;
 
import java.util.List;
 
import com.zking.biz.IGoodsBiz;
import com.zking.dao.IGoodsDao;
import com.zking.dao.impl.GoodsDaolmpl;
import com.zking.pojo.Goods;
 
public class GoodsBizlmpl implements IGoodsBiz{
	
	  private IGoodsDao goodsDao=new GoodsDaolmpl();
 
	  @Override
	    public List getAll(int page) {
	        return goodsDao.getAll(page);
	    }
 
	    @Override
	    public Goods getOne(Integer id) {
	        return goodsDao.getOne(id);
	    }
 
		@Override
		public int getRowCount() {
			// TODO Auto-generated method stub
			return goodsDao.getRowCount();
		}
 
}

index.jsp:

<%@page import="org.apache.jasper.tagplugins.jstl.core.ForEach"%>
<%@page import="com.zking.pojo.Goods"%>
<%@page import="com.zking.biz.impl.GoodsBizlmpl"%>
<%@page import="com.zking.biz.IGoodsBiz"%>
<%@page import="com.zking.pojo.User"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>



    
    Document
    
    
    
    
    

 







    

欢迎光临嘿嘿嘿SuperMarket

尊贵的${sessionScope.user.account }

商品序号 商品名称 商品单价 商品描述 操作
${g.id} ${g.name} ${g.price} ${g.info }

doIndex.jsp:

<%@page import="com.zking.biz.impl.GoodsBizlmpl"%>
<%@page import="com.zking.biz.IGoodsBiz"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
     <%
       String parameter = request.getParameter("ipage");
       int ipage=1;//默认第一页
       if(parameter!=null){
    	   ipage=Integer.parseInt(parameter);
       }
       
       //得到商品的Biz
       IGoodsBiz goodsBiz=new GoodsBizlmpl();
       //将商品查询出来 并且放到请求域当中
       request.setAttribute("goods", goodsBiz.getAll(ipage));
       //算出也数,带导index.jsp
       int row = goodsBiz.getRowCount();
 
       request.setAttribute("maxPage", (int)Math.ceil(row*1.0/4)) ;
       
       request.setAttribute("ipage", ipage);
       //把数据携带导index.jsp
       request.getRequestDispatcher("index.jsp").forward(request,response);
       %>

https://blog.csdn.net/m0_63772104/article/details/car.jsp:

<%@page import="com.zking.vo.CarItem"%>
<%@page import="java.util.List"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>


 

    
    Document
    
    
    
    
    

 

    

欢迎光临嘿嘿嘿购物车

尊贵的${user.account}

退出登陆

商品序号 商品名称 商品个数 商品总价 操作
${c.goods.id } ${c.goods.name }
- +
${c.sum} 删除

当前购物车总价 xx 点我结算

本期分享内容中使用了一部分EL表达式和JSTL标签代替了一部分Java代码
好了今天的内容就分享到这了

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/839029.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号