JAVAEE——BOS物流項目05:OCUpload、POI、pinyin4J、重構分頁代碼、分區添加、combobox

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

1 學習計劃 1、實現區域導入功能 n OCUpload一鍵上傳插件使用 n 將文件上傳到Action n POI簡介 n 使用POI解析Excel文件 n 完成資料庫操作 n 使用pinyin4J生成簡碼和城市編碼 2、區域分頁查詢 n 頁面調整 n 服務端實現 3、重構分頁代碼 n BaseAc ...


學習計劃

1、實現區域導入功能

n OCUpload一鍵上傳插件使用

將文件上傳到Action

n POI簡介

使用POI解析Excel文件

n 完成資料庫操作

使用pinyin4J生成簡碼和城市編碼

2、區域分頁查詢

n 頁面調整

n 服務端實現

3、重構分頁代碼

n BaseAction

子類Action

4、分區添加功能

n 什麼是分區

頁面調整(combobox使用)

n 服務端實現

 

 

實現區域導入功能

2.1 jquery OCUpload一鍵上傳插件使用

OCUploadOne Click Upload

第一步:將js文件引入頁面

<script type="text/javascript" src="${pageContext.request.contextPath }/js/jquery-1.8.3.js"></script>
<script type="text/javascript" src="${pageContext.request.contextPath }/js/jquery.ocupload-1.1.2.js"></script>

第二步:在頁面中提供任意一個元素

 

第三步:調用插件提供的upload方法,動態修改HTML頁面元素

<script type="text/javascript">
    $(function(){
        //頁面載入完成後,調用插件的upload方法,動態修改了HTML頁面元素
        $("#myButton").upload({
            action:'xxx.action',
            name:'myFile'
        });
    });
</script>

 

 

2.2 在服務端接收上傳的文件

Action中提供一個File類型的屬性,名稱和上傳的文件輸入框名稱一致regionFile

@Controller
@Scope("prototype")
public class RegionAction extends BaseAction<Region>{
    //屬性驅動,接收上傳的文件
    private File regionFile;

    public void setRegionFile(File regionFile) {
        this.regionFile = regionFile;
    }
    
    /**
     * 區域導入
     */
    public String importXls(){
        System.out.println(regionFile);
        return NONE;
    }
}

 

2.3 apache POI技術

Apache POIApache軟體基金會的開放源碼函式庫,POI提供APIJava程式對Microsoft Office格式檔案讀和寫的功能。

 

下載開發包:

 

 

解壓上面的zip文件:

 

 

 

在項目中引入POI的依賴:

        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.11</version>
        </dependency>

 

POI使用:

@Test
    public void test1() throws FileNotFoundException, IOException{
        String filePath = "C:\\Users\\zhaoqx\\Desktop\\BOS項目(黑馬32期)\\BOS-day05\\資料\\區域導入測試數據.xls";
        //包裝一個Excel文件對象
        HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(new File(filePath)));
        //讀取文件中第一個Sheet標簽頁
        HSSFSheet hssfSheet = workbook.getSheetAt(0);
        //遍歷標簽頁中所有的行
        for (Row row : hssfSheet) {
            System.out.println();
            for (Cell cell : row) {
                String value = cell.getStringCellValue();
                System.out.print(value + " ");
            }
        }
    }

 

2.4 pinyin4J

 

        <!-- 引入pinyin4J的依賴 -->
        <dependency>
            <groupId>com.belerweb</groupId>
            <artifactId>pinyin4j</artifactId>
            <version>2.5.0</version>
        </dependency>

 

@Test
    public void test1(){
        //河北省    石家莊市    橋西區
        String province = "河北省";
        String city = "石家莊市";
        String district = "橋西區";
        //簡碼---->>HBSJZQX
        
        province = province.substring(0, province.length() - 1);
        city = city.substring(0, city.length() - 1);
        district = district.substring(0, district.length() - 1);
        
        String info = province + city + district;
        
        String[] headByString = PinYin4jUtils.getHeadByString(info);
        String shortcode = StringUtils.join(headByString);
        System.out.println(shortcode);
        
        //城市編碼---->>shijiazhuang
        String citycode = PinYin4jUtils.hanziToPinyin(city, "");
        System.out.println(citycode);
    }

 

 

區域數據分頁查詢

 利用之前已經寫好的pageQuery

 

重構分頁代碼

將重覆分代碼統一抽取到BaseAction

 

 

 

分區數據添加功能

區域範圍很大,對區域進行細分產生分區

 

5.1 easyUI combobox下拉框使用

製作一個json文件:

 

    <input data-options="url:'${pageContext.request.contextPath }/json/combobox_data.json',
            valueField:'id',
            textField:'name'" 
            class="easyui-combobox">

 

 

5.2 使用combobox展示區域數據

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

 

 

 

第一步:修改頁面中combobox

 

 

添加獲取name的方法

 

 

 

第二步:在RegionAction中提供listajax方法

 

 

第三步:在RegionDao中擴展方法

 

 

第四步:為添加視窗中保存按鈕綁定事件

 

 

 

5.3 服務端實現

創建分區對應的ActionServiceDao

 

分頁查詢問題

Java對象轉為json過程中,因為對象之間有相互引用關係,會發生死迴圈問題,解決方式,排除其中屬性

 

 


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

-Advertisement-
Play Games
更多相關文章
  • 前言 進入自己github主頁會看到自己的提交記錄,如果某天沒有提交記錄,那天的小方框就顯示灰色。強迫症的我,每次進來看著就感覺不爽, 想著自己每天記得提交點東西,爭取像 "阮一峰" 大神一樣,每天都有提交記錄。 但是,畢竟是人,哪天忙了就會忘記提交,所以想著能不能實現在自己阿裡雲伺服器(linux ...
  • 關於元素居中的總結 包括:1.不使用定位 a.水平居中 b.垂直居中 c.其他居中 2.使用定位 a.父元素高寬固定 ... ...
  • 首先下載eCharts源代碼,然後可以按照官網的5分鐘上手ECharts教程做一個簡單的例子,這裡為了將前端顯示和後端邏輯分開,可以建一個index.html和一個繪製圖表的chartTest.js,代碼如下: js代碼如下: 通過上面的代碼就可以繪製出下麵這樣的一個簡單的圖表 其中xAxis和yA ...
  • 作為軟體開發人員,我們已知道思考如何將應用程式因數分解成組件部分。 這是對象導向、軟體抽象和組件化的中心模式。 現在,這種因數分解往往以共用庫和技術層之間的類與介面呈現。 通常採用一種分層方法,有後端存儲、中間層業務邏輯和前端用戶界面 (UI)。 過去幾年來的變化是身為開發人員的我們,開始為業務驅動 ...
  • 一致性演算法 是分散式系統中最重要的問題之一。錶面上看,這似乎很簡單,只是讓幾個節點在某些方面達成一致。在本篇之中,會帶大家完整的梳理分散式系統之中的共識演算法,來更加深刻的理解分散式系統的設計。 1.原子提交和兩階段提交(2PC) 原子提交防止了資料庫處於半更新的狀態,這對於需要滿足多對象事務和維護次 ...
  • 該模塊作用是完成Python數值和C語言結構體的Python字元串形式間的轉換。這可以用於處理存儲在文件中或從網路連接中存儲的二進位數據,以及其他數據源。 用途: 在Python基本數據類型和二進位數據之間進行轉換 模塊提供了用於在位元組字元串和Python原生數據類型之間轉換函數,比如數字和字元串。 ...
  • Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 5934 Accepted Submission(s): 1845 Problem Descrip ...
  • 現代信息系統應該是避不開大數據處理的。作為一個通用的系統集成工具也必須具備大數據存儲和讀取能力。cassandra是一種分散式的資料庫,具備了分散式資料庫高可用性(high-availability)特性,對於一個實時大型分散式集成系統來說是核心支柱。與傳統的關係資料庫對比,cassandra從數據 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...