JAVAEE——BOS物流項目04:學習計劃、datagrid、分頁查詢、批量刪除、修改功能

来源:https://www.cnblogs.com/xieyupeng/archive/2018/02/19/8453401.html
-Advertisement-
Play Games

1 學習計劃 1、datagrid使用方法(重要) n 將靜態HTML渲染為datagrid樣式 n 發送ajax請求獲取json數據創建datagrid n 使用easyUI提供的API創建datagrid(掌握) 2、實現取派員分頁查詢 n 調整頁面基於datagrid發送ajax請求 n 創建 ...


1 學習計劃

1datagrid使用方法(重要)

將靜態HTML渲染為datagrid樣式

發送ajax請求獲取json數據創建datagrid

使用easyUI提供的API創建datagrid(掌握)

2、實現取派員分頁查詢

調整頁面基於datagrid發送ajax請求

創建PageBean封裝分頁參數

n 定義通用分頁查詢方法

將分頁查詢結果轉為json返回

3、取派員批量刪除

n 頁面調整

n 服務端實現

4、取派員修改

n 頁面調整

n 服務端實現

 

 

datagrid使用方法(重要)

2.1 將靜態HTML渲染為datagrid樣式

<!-- 方式一:將靜態HTML渲染為datagrid樣式 -->
    <table class="easyui-datagrid">
        <thead>
            <tr>
                <th data-options="field:'id'">編號</th>
                <th data-options="field:'name'">姓名</th>
                <th data-options="field:'age'">年齡</th>
            </tr>
        </thead>
        <tbody>
            <tr>
                <td>001</td>
                <td>小明</td>
                <td>90</td>
            </tr>
            <tr>
                <td>002</td>
                <td>老王</td>
                <td>3</td>
            </tr>
        </tbody>
    </table>

 

 

2.2 發送ajax請求獲取json數據創建datagrid

提供json文件:

 

<!-- 方式二:發送ajax請求獲取json數據創建datagrid -->
    <table data-options="url:'${pageContext.request.contextPath }/json/datagrid_data.json'" 
            class="easyui-datagrid">
        <thead>
            <tr>
                <th data-options="field:'id'">編號</th>
                <th data-options="field:'name'">姓名</th>
                <th data-options="field:'age'">年齡</th>
            </tr>
        </thead>
    </table>

 

2.3 使用easyUI提供的API創建datagrid(掌握)

    <!-- 方式三:使用easyUI提供的API創建datagrid -->
    <script type="text/javascript">
        $(function(){
            //頁面載入完成後,創建數據表格datagrid
            $("#mytable").datagrid({
                //定義標題行所有的列
                columns:[[
                          {title:'編號',field:'id',checkbox:true},
                          {title:'姓名',field:'name'},
                          {title:'年齡',field:'age'},
                          {title:'地址',field:'address'}
                          ]],
                //指定數據表格發送ajax請求的地址
                url:'${pageContext.request.contextPath }/json/datagrid_data.json',
                rownumbers:true,
                singleSelect:true,
                //定義工具欄
                toolbar:[
                         {text:'添加',iconCls:'icon-add',
                             //為按鈕綁定單擊事件
                             handler:function(){
                                 alert('add...');
                              }
                         },
                         {text:'刪除',iconCls:'icon-remove'},
                         {text:'修改',iconCls:'icon-edit'},
                         {text:'查詢',iconCls:'icon-search'}
                         ],
                //顯示分頁條
                pagination:true
            });
        });
    </script>

 

如果數據表格中使用了分頁條,要求服務端響應的json變為:

 

 

請求:

 

 

響應:

 

 

取派員分頁查詢

頁面:WEB-INF/pages/base/staff.jsp

 

3.1 頁面調整

修改頁面中datagridURL地址

 

3.2 服務端實現

3.2.1 包裝PageBean工具類

封裝分頁相關的屬性

 

 

 

3.2.2 BaseDao中擴展通用分頁查詢方法

    /**
     * 通用分頁查詢方法
     */
    public void pageQuery(PageBean pageBean) {
        int currentPage = pageBean.getCurrentPage();
        int pageSize = pageBean.getPageSize();
        DetachedCriteria detachedCriteria = pageBean.getDetachedCriteria();
        
        //查詢total---總數據量
        detachedCriteria.setProjection(Projections.rowCount());//指定hibernate框架發出sql的形式----》select count(*) from bc_staff;
        List<Long> countList = (List<Long>) this.getHibernateTemplate().findByCriteria(detachedCriteria);
        Long count = countList.get(0);
        pageBean.setTotal(count.intValue());
        
        //查詢rows---當前頁需要展示的數據集合
        detachedCriteria.setProjection(null);//指定hibernate框架發出sql的形式----》select * from bc_staff;
        int firstResult = (currentPage - 1) * pageSize;
        int maxResults = pageSize;
        List rows = this.getHibernateTemplate().findByCriteria(detachedCriteria, firstResult, maxResults);
        pageBean.setRows(rows);
    }

 

 

3.2.3 StaffAction中提供分頁查詢方法

    //屬性驅動,接收頁面提交的分頁參數
    private int page;
    private int rows;
    
    /**
     * 分頁查詢方法
     * @throws IOException 
     */
    public String pageQuery() throws IOException{
        PageBean pageBean = new PageBean();
        pageBean.setCurrentPage(page);
        pageBean.setPageSize(rows);
        //創建離線提交查詢對象
        DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Staff.class);
        pageBean.setDetachedCriteria(detachedCriteria);
        staffService.pageQuery(pageBean);
        
        //使用json-lib將PageBean對象轉為json,通過輸出流寫回頁面中
        //JSONObject---將單一對象轉為json
        //JSONArray----將數組或者集合對象轉為json
        JsonConfig jsonConfig = new JsonConfig();
        //指定哪些屬性不需要轉json
        jsonConfig.setExcludes(new String[]{"currentPage","detachedCriteria","pageSize"});
        String json = JSONObject.fromObject(pageBean,jsonConfig).toString();
        ServletActionContext.getResponse().setContentType("text/json;charset=utf-8");
        ServletActionContext.getResponse().getWriter().print(json);
        return NONE;
    }

 

取派員批量刪除

在取派員表中存在一個刪除標識位deltag1表示已刪除 ,0表示未刪除

4.1 頁面調整

數據表格datagrid提供的方法,用於獲取所有選中的行:

 

 

修改刪除按鈕綁定的事件:

function doDelete(){
        //獲取數據表格中所有選中的行,返回數組對象
        var rows = $("#grid").datagrid("getSelections");
        if(rows.length == 0){
            //沒有選中記錄,彈出提示
            $.messager.alert("提示信息","請選擇需要刪除的取派員!","warning");
        }else{
            //選中了取派員,彈出確認框
            $.messager.confirm("刪除確認","你確定要刪除選中的取派員嗎?",function(r){
                if(r){
                    
                    var array = new Array();
                    //確定,發送請求
                    //獲取所有選中的取派員的id
                    for(var i=0;i<rows.length;i++){
                        var staff = rows[i];//json對象
                        var id = staff.id;
                        array.push(id);
                    }
                    var ids = array.join(",");//1,2,3,4,5
                    location.href = "staffAction_deleteBatch.action?ids="+ids;
                }
            });
        }
    }

 

4.2 服務端實現

 

第一步:在StaffAction中創建deleteBatch批量刪除方法



    //屬性驅動,接收頁面提交的ids參數
    private String ids;
    
    /**
     * 取派員批量刪除
     */
    public String deleteBatch(){
        staffService.deleteBatch(ids);
        return LIST;
    }

第二步:在Service中提供批量刪除方法
    /**
     * 取派員批量刪除
     * 邏輯刪除,將deltag改為1
     */
    public void deleteBatch(String ids) {//1,2,3,4
        if(StringUtils.isNotBlank(ids)){
            String[] staffIds = ids.split(",");
            for (String id : staffIds) {
                staffDao.executeUpdate("staff.delete", id);
            }
        }
    }
第三步:在Staff.hbm.xml中提供HQL語句,用於邏輯刪除取派員
    <!-- 取派員邏輯刪除 -->
    <query name="staff.delete">
        UPDATE Staff SET deltag = '1' WHERE id = ?
    </query>
由於dtd約束,所以query和class是同級的,如果嵌套寫入會報錯。

 

取派員修改功能

5.1 頁面調整

第一步:為數據表格綁定雙擊事件

 

第二步:複製頁面中添加取派員視窗,獲得修改取派員視窗

 

 

第三步:定義function

    //數據表格綁定的雙擊行事件對應的函數
    function doDblClickRow(rowIndex, rowData){
        //打開修改取派員視窗
        $('#editStaffWindow').window("open");
        //使用form表單對象的load方法回顯數據
        $("#editStaffForm").form("load",rowData);
    }

 

5.2 服務端實現

StaffAction中創建edit方法,修改取派員信息

 

    /**
     * 修改取派員信息
     */
    public String edit(){
        //顯查詢資料庫,根據id查詢原始數據
        Staff staff = staffService.findById(model.getId());
        //使用頁面提交的數據進行覆蓋
        staff.setName(model.getName());
        staff.setTelephone(model.getTelephone());
        staff.setHaspda(model.getHaspda());
        staff.setStandard(model.getStandard());
        staff.setStation(model.getStation());
        staffService.update(staff);
        return LIST;
    }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 3 添加標題圖片 首先,要加入圖標,需要.ico格式的圖片才可以。 可以在:http://www.bitbug.net/ 這裡上傳圖片,製成.ico格式的文件。 然後在html的<head>標簽中插入: <link rel="shortcut icon" href="WEB-INF/favicon. ...
  • 近期幫助別人做了個網站需要能在網路上訪問。本人也是第一次製作網站,不斷摸索之後終於成功了。下麵是過程及遇到的問題解決筆記。 一、購買功能變數名稱和伺服器 我的功能變數名稱和伺服器都是在騰訊雲上購買的。流程騰訊雲上都有,就是功能變數名稱的備案時間比較長。 伺服器購買好之後需要安裝好操作系統。我安裝的是windows serv ...
  • 問題: 有一個國家發現了5座金礦,每座金礦的黃金儲量不同,需要參與挖掘的工人數也不同。參與挖礦工人的總數是10人。 每座金礦要麼全挖,要麼不挖,不能派出一半人挖取一半金礦。要求用程式求解出,要想得到儘可能多的黃金,應該選擇挖取哪幾座金礦? 動態規劃有三個核心元素:最優子結構、邊界、狀態轉移 方程式。 ...
  • 在ASP.NET Web API里使用Autofac 通過NuGet安裝Autofac.WebApi。(Nuget會安裝依賴的Autofac.dll)。 PM > Install-Package Autofac.WebApi 引用如下命名空間: using Autofac; using Autofa ...
  • 參考文獻:《大話設計模式》 一、單一職責原則(SRP) 定義:就一個類而言,應該僅有一個引起它變化的原因。 解釋:如果一個類承擔的職責過多,就等於是把這些職責耦合在一起,一個職責的變化可能會削弱或者抑制這個類完成其他職責的能力。 這種耦合會導致脆弱的設計,當變化發生時,設計會遭受到意想不到的破壞。 ...
  • SQL Server 2008基於策略的管理,基於策略的管理(Policy Based Management),使DBA們可以制定管理策略,並將這些策略應用到伺服器、資料庫以及數據環境中的其他對象上去。基於動作策略(Action Policy)的異常處理使開發人員可以為異常處理制定策略,簡單的說,動 ...
  • 較複雜的應用程式都是由多個項目組織成的,項目可以劃分成程式集(Assemblies)和宿主(Hosts),也就是應用程式的入口。 Assemblies 通常是常見的類庫項目,包括可以重用的功能以方便測試,通常包括下麵的組件: Views, Controllers 和 Models; 服務; 持久類 ...
  • 在.NET上現在存在許多的依賴註入容器, 如:Castle Windsor、StructureMap、Autofac 、Unity。 這裡主要介紹一下Autofac,Autofac和其他容器的不同之處是它和C#語言的結合非常緊密,在使用過程中對你的應用的侵入性幾乎為零,更容易與第三方的組件集成。Au ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...