<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 70,comments - 408,trackbacks - 0

    最近項目需要,因為時間問題我用最簡單的方法做了一個查詢分頁+CheckBox的全選提交,我覺得非常適合小項目和類似郵件列表的功能.下面貼出我的代碼,希望朋友們多給我提毛病.
    主要代碼都寫在JSP里.下面是一個apply_note.jsp:
    <%@page contentType="text/html;charset=GBK" language="java"%>
    <%@ page import="java.sql.*"%>
    <%@ page import="com.deepdo.common.connect.ConSql"%>
    <%@ taglib uri="/WEB-INF/struts-logic.tld" prefix="logic" %>
    <%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean" %>
    <style type=text/css>
    td,th,p,span,div,a,A {font-size:12px;text-decoration:none}
    .blak a {color:#000; text-decoration:none}
    .blak a:hover {color:#f00; text-decoration:underline}
    </style>
    <body>
    <jsp:include page="/include/deepdo.jsp" flush="true"/>
    <table width="700" border="0" align="center" cellpadding="0" cellspacing="0"? height="450">
    ? <tr>
    ?<td valign="top" class="bg_td1" height="450" width="160">
    ?<jsp:include page="/include/navigation.jsp" flush="true"/>
    ?</td>
    ?<td valign="top" class="bg_td1" height="450" width="540">
    ?<table width="590" border="0" align="center" cellpadding="2" cellspacing="2" bgcolor="#FAF9F5">
    ????????? <tr>
    ??????????? <td background="resume/images/color.jpg" class="font4"> <img src="resume/images/dot.gif">
    ????????????? 工作申請記錄</td>
    ????????? </tr>
    ??????? </table>
    ??????? <table width="590" border="0" align="center" cellpadding="4" cellspacing="2">
    ??????? <%
    ??//變量聲明
    ??Connection sqlCon; //數據庫連接對象
    ??Statement sqlStmt; //SQL語句對象
    ??ResultSet sqlRst; //結果集對象
    ??String strCon; //數據庫連接字符串
    ??String strSQL; //SQL語句
    ??int intPageSize; //一頁顯示的記錄數
    ??int intRowCount; //記錄總數
    ??int intPageCount; //總頁數
    ??int intPage; //待顯示頁碼
    ??String strPage;
    ??int i;
    ??//設置一頁顯示的記錄數
    ??intPageSize = 10;
    ??//取得待顯示頁碼
    ??strPage = request.getParameter("page");
    ??if(strPage==null){//表明在QueryString中沒有page這一個參數,此時顯示第一頁數據
    ??intPage = 1;
    ??}
    ??else{//將字符串轉換成整型
    ??intPage = java.lang.Integer.parseInt(strPage);
    ??if(intPage<1) intPage = 1;
    ??}
    ??//獲取一個TOMCAT配置的連接池
    ? sqlCon = ConSql.getCon();
    ??//創建一個可以滾動的只讀的SQL語句對象
    ??sqlStmt = sqlCon.createStatement(java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY);
    ??//準備SQL語句
    ??strSQL = "select * from apply_note where userid="+request.getAttribute("userid");
    ??//執行SQL語句并獲取結果集
    ??sqlRst = sqlStmt.executeQuery(strSQL);
    ??//獲取記錄總數
    ??sqlRst.last();
    ??intRowCount = sqlRst.getRow();
    ??//記算總頁數
    ??intPageCount = (intRowCount+intPageSize-1) / intPageSize;
    ??//調整待顯示的頁碼
    ??if(intPage>intPageCount) intPage = intPageCount;
    ??%>
    ??<tr>
    ??<td align="center" bgcolor="#efefef" width="150" height="27">已經申請過的職位</td>
    ??<td align="center" bgcolor="#efefef" width="140" height="27">公司名稱</td>
    ??<td align="center" bgcolor="#efefef" width="75" height="27">申請時間</td>
    ??<td align="center" bgcolor="#efefef" width="25" height="27"><input type=CheckBox name="selectAll" onClick="selectAll();"></td>
    ??</tr>
    ??<%
    ??if(intPageCount>0){
    ??//將記錄指針定位到待顯示頁的第一條記錄上
    ??sqlRst.absolute((intPage-1) * intPageSize + 1);
    ??//顯示數據
    ??i = 0;
    ??while(i<intPageSize && !sqlRst.isAfterLast()){
    ??%>
    ??<form name ="noteForm" action="noteRemove.do" method="post">
    ??<tr>
    ??<td><a href=<%=sqlRst.getString("url")%> target="_blank"><%=sqlRst.getString("job")%></a></td>
    ??<td><%=sqlRst.getString("unit")%></td>
    ??<td><%=sqlRst.getString("date_time")%></td>
    ??<td width="26" align="center"><input type=CheckBox name="id" value=<%=sqlRst.getString("id")%>></td>
    ??</tr>
    ??<%
    ??sqlRst.next();
    ??i++;
    ??}
    ??}
    ??%>
    ??<tr>
    ??<td>
    ??<a href="note.do?page=1">首頁</a>&nbsp;&nbsp;
    ??<%if(intPage>1){%><a href="note.do?page=<%=intPage-1%>">上一頁</a><%}
    ??else {%><a href="#" title="已經是第一頁">上一頁</a><%}%>&nbsp;&nbsp;
    ??<%if(intPage<intPageCount){%><a href="note.do?page=<%=intPage+1%>">下一頁</a><%}
    ??else {%><a href="#" title="已經是最后一頁">下一頁</a><%}%>&nbsp;&nbsp;
    ??<a href=note.do?page=<%=intPageCount%>>末頁</a>
    ??</td>
    ??<td>
    ??共 <%=intPageCount%> 頁申請記錄&nbsp;&nbsp;
    ??當前為第 <%=intPage%> 頁&nbsp;&nbsp;
    ??</td>
    ??<td>&nbsp;</td>
    ??<td align="center"><input type="submit" value="刪除" onClick="manageSubmit();"></td>
    ??<input type="hidden" name="checkvalue" value="">
    ??</tr>
    ??</form>
    ??<%
    ??//關閉結果集
    ??sqlRst.close();
    ??//關閉SQL語句對象
    ??sqlStmt.close();
    ??//關閉數據庫
    ??sqlCon.close();
    ??%>?
    ??????? </table>
    ??? </td>
    ? </tr>
    </table>
    <jsp:include page="/include/tail.html" flush="true"/>
    </body>
    <script language="javascript">
    function manageSubmit(){
    ?var ChkEls=document.getElementsByName("Id");
    ?var checkedIds="";
    ?for(var i=0;i<ChkEls.length;i++){
    ??if(ChkEls.item(i).type != "checkbox")continue;
    ??var oEl = ChkEls.item(i);
    ??if(oEl.checked) {
    ???checkedIds = checkedIds + (oEl.value + ",");
    ??}
    ?}
    ?document.noteForm.checkvalue.value = checkedIds;
    ?if ( checkedIds == "" ) return false;
    ?return true;
    }

    function selectAll(){
    ?var ChkEl = document.getElementsByName("selectAll").item(0);
    ?var ChkEls=document.getElementsByName("Id");
    ?for(var i=0;i<ChkEls.length;i++){
    ??if(ChkEls.item(i).type != "checkbox")continue;
    ??var oEl = ChkEls.item(i);
    ??oEl.status=ChkEl.status;
    ?}
    }
    </script>
    </html>
    下面是一個Action,基本沒處理業務邏輯,就是從Cookie里獲得了用戶的id.

    這樣處理分頁感覺超級簡單,這個Action就是起到了一個中轉的作用,沒有實際業務功能,如果沒有他,那個JSP只需要修改一下上下頁的連接地址為本身.就可以自己實現查詢分頁功能.JSP頁最后的兩個JS方法是負責處理CheckBox全選和,和提交CheckBox的值為的問題的方法.希望朋友們幫忙指點一下我代碼中的不足,互相學習互相進步.

    posted on 2006-06-02 10:57 我心依舊 閱讀(3977) 評論(2)  編輯  收藏

    FeedBack:
    # re: 簡單的查詢分頁+CheckBox的全選提交,解決方法.
    2006-06-11 11:09 | 青誠
    你的這段程序邏輯上是沒有問題,但如果是數據量非常大的話,運行起來就會有問題。另外最關鍵的是你在jsp里面頻繁的打開關閉連接等是很浪費資源的,還有我認為在jsp就只應該完成顯示功能,不應該包含具體的業務邏輯。  回復  更多評論
      
    # re: 簡單的查詢分頁+CheckBox的全選提交,解決方法.
    2007-03-29 16:16 | shining
    暈啊 將那么多java代碼寫在jsp頁面上,這也算MVC嗎???
    給你一些建議吧!
    1)將分頁邏輯封裝在一個bean里面,bean里面只接收3個參數(起始頁,分頁單位,待分頁的List), 在Action里面分好頁后將bean傳給jsp,再在jsp中通過${obj.value}的表達式來引用當前頁數,全部頁數,等屬性.
    2)CheckBox的全選提交方法可以寫在一個外部的js文件檔里面,然后引用就OK了.

    看來你還比較缺乏OO的思維啊!  回復  更多評論
      

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 最新免费jlzzjlzz在线播放| 日韩午夜理论免费TV影院| 一区二区无码免费视频网站| 亚洲第一永久在线观看| 91成人在线免费视频| 中文字幕亚洲免费无线观看日本 | 亚洲中文无码卡通动漫野外| 国产免费毛不卡片| 亚洲一卡2卡三卡4卡无卡下载| 免费无码AV片在线观看软件| 亚洲欧美乱色情图片| 国产男女猛烈无遮档免费视频网站| 成a人片亚洲日本久久| 婷婷亚洲天堂影院| 成人A毛片免费观看网站| 亚洲狠狠婷婷综合久久久久| 午夜精品射精入后重之免费观看| 亚洲综合激情六月婷婷在线观看| 成人免费福利视频| 亚洲a∨无码精品色午夜| 亚洲国产中文v高清在线观看| 中文字幕免费人成乱码中国| 亚洲精品一卡2卡3卡三卡四卡| 免费a级毛片高清视频不卡| 久久久久亚洲国产AV麻豆| 亚洲尤码不卡AV麻豆| 99re在线精品视频免费| 亚洲午夜精品一区二区麻豆| 亚洲AV无码乱码在线观看性色扶 | 亚洲日本在线观看| 毛片免费视频播放| 一区二区在线免费视频| 亚洲欧洲日韩不卡| 国产成人高清精品免费鸭子| 在线免费观看伊人三级电影| 亚洲依依成人精品| 爱情岛论坛网亚洲品质自拍| 99久久久精品免费观看国产 | 99在线在线视频免费视频观看| 33333在线亚洲| 亚洲日韩精品A∨片无码|