MiniUI子表繪製和彙總數據

来源:http://www.cnblogs.com/xq-1209/archive/2017/12/07/8000992.html
-Advertisement-
Play Games

$("#ZB").attr("ondrawsummarycell", "ondrawsummarycell"); // ZBMX需要替換為子表對應控制項的控制項編號 彙總數據 $("#ZB").attr("ondrawcell", "ondrawcell"); // ZBMX需要替換為子表對應控制項的控制項... ...


$("#ZB").attr("ondrawsummarycell", "ondrawsummarycell");  // ZBMX需要替換為子表對應控制項的控制項編號    彙總數據
$("#ZB").attr("ondrawcell", "ondrawcell");  // ZBMX需要替換為子表對應控制項的控制項編號    繪製表格
//繪製表格
function ondrawcell(e) {
     var record = e.record;
     if (e.field == "JEY") {
         var RS = record.RS;//人數
        if (RS == null || RS == undefined || RS == "") {
             RS = 0;
         }
         var BZY = record.BZY; //標準(元)
        if (BZY == null || BZY == undefined || BZY == "") {
              BZY = 0;
         }
         var sum = parseFloat(RS) * parseFloat(BZY);
         record.JEY = sum;
         e.cellHtml = sum;
      }
  }
  //彙總數據
 function ondrawsummarycell(e) {
     if (e.field == 'RS') {
         mini.getbyName("HJRS").setValue(e.value);

    }
     if (e.field == "JEY")  // SBJE需要替換為子表中數字列對應控制項的控制項編號
    {
         var ZJ = mini.getbyName("HJXX");  // ZJ需要替換為顯示總計數字對應控制項的控制項編號
        ZJ.setValue(e.value);
         var ZJDX = mini.getbyName("HJDX");  // ZJDX需要替換為顯示總計中文數字對應控制項的控制項編號
        var dx = Arabia_to_Chinese(e.value.toString());
         ZJDX.setValue(dx);
     }
 }

function Arabia_to_Chinese(Num) {
     for (i = Num.length - 1; i >= 0; i--) {
         Num = Num.replace(",", "")//替換tomoney()中的“,”
        Num = Num.replace(" ", "")//替換tomoney()中的空格
    }
     //Num = Num.replace("¥","")//替換掉可能出現的¥字元
    if (isNaN(Num)) {
         //驗證輸入的字元是否為數字
        alert("請檢查小寫金額是否正確");
         return;
     }
     //---字元處理完畢,開始轉換,轉換採用前後兩部分分別轉換---//
     part = String(Num).split(".");
     newchar = "";
     //小數點前進行轉化
    for (i = part[0].length - 1; i >= 0; i--) {
         if (part[0].length > 10) { alert("位數過大,無法計算"); return ""; } //若數量超過拾億單位,提示
        tmpnewchar = "";
         perchar = part[0].charAt(i);
         switch (perchar) {
             case "0": tmpnewchar = "零" + tmpnewchar; break;
             case "1": tmpnewchar = "壹" + tmpnewchar; break;
             case "2": tmpnewchar = "貳" + tmpnewchar; break;
             case "3": tmpnewchar = "叄" + tmpnewchar; break;
             case "4": tmpnewchar = "肆" + tmpnewchar; break;
             case "5": tmpnewchar = "伍" + tmpnewchar; break;
             case "6": tmpnewchar = "陸" + tmpnewchar; break;
             case "7": tmpnewchar = "柒" + tmpnewchar; break;
             case "8": tmpnewchar = "捌" + tmpnewchar; break;
             case "9": tmpnewchar = "玖" + tmpnewchar; break;
         }
         switch (part[0].length - i - 1) {
             case 0: tmpnewchar = tmpnewchar + "元"; break;
             case 1: if (perchar != 0) tmpnewchar = tmpnewchar + "拾"; break;
             case 2: if (perchar != 0) tmpnewchar = tmpnewchar + "佰"; break;
             case 3: if (perchar != 0) tmpnewchar = tmpnewchar + "仟"; break;
             case 4: tmpnewchar = tmpnewchar + "萬"; break;
             case 5: if (perchar != 0) tmpnewchar = tmpnewchar + "拾"; break;
             case 6: if (perchar != 0) tmpnewchar = tmpnewchar + "佰"; break;
             case 7: if (perchar != 0) tmpnewchar = tmpnewchar + "仟"; break;
             case 8: tmpnewchar = tmpnewchar + "億"; break;
             case 9: tmpnewchar = tmpnewchar + "拾"; break;
         }
         newchar = tmpnewchar + newchar;
     }
     //小數點之後進行轉化
    if (Num.indexOf(".") != -1) {
         if (part[1].length > 2) {
             //alert("小數點之後只能保留兩位,系統將自動截段");
             part[1] = part[1].substr(0, 2);
         }
         for (i = 0; i < part[1].length; i++) {
             tmpnewchar = "";
             perchar = part[1].charAt(i);
             switch (perchar) {
                 case "0": tmpnewchar = "零" + tmpnewchar; break;
                 case "1": tmpnewchar = "壹" + tmpnewchar; break;
                 case "2": tmpnewchar = "貳" + tmpnewchar; break;
                 case "3": tmpnewchar = "叄" + tmpnewchar; break;
                 case "4": tmpnewchar = "肆" + tmpnewchar; break;
                 case "5": tmpnewchar = "伍" + tmpnewchar; break;
                 case "6": tmpnewchar = "陸" + tmpnewchar; break;
                 case "7": tmpnewchar = "柒" + tmpnewchar; break;
                 case "8": tmpnewchar = "捌" + tmpnewchar; break;
                 case "9": tmpnewchar = "玖" + tmpnewchar; break;
             }
             if (i == 0) tmpnewchar = tmpnewchar + "角";
             if (i == 1) tmpnewchar = tmpnewchar + "分";
             newchar = newchar + tmpnewchar;
         }
     }
     //替換所有無用漢字
    while (newchar.search("零零") != -1)
     { newchar = newchar.replace("零零", "零"); }
     newchar = newchar.replace("零億", "億");
     newchar = newchar.replace("億萬", "億");
     newchar = newchar.replace("零萬", "萬");
     newchar = newchar.replace("零元", "元");
     newchar = newchar.replace("零角", "");
     newchar = newchar.replace("零分", "");
     if (newchar.charAt(newchar.length - 1) == "元" || newchar.charAt(newchar.length - 1) == "角")
     { newchar = newchar + "整"; }

    return newchar;
 }

 


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

-Advertisement-
Play Games
更多相關文章
  • 最近開始搞安卓,使用AS啟動項目時老是報各種錯誤,而網上這方面的資料很多都解決不了。只能邊實驗邊做。 定位到avd manager或sdk manager無法打開,網上找了很多資料,都不能解決,知道看見下麵一篇文章。 sdk manager打不開閃退問題完美解決2017年最新方法 當看到博主辛辛苦苦 ...
  • 近日,在開發過程中 遇到了 Layout 代碼中設置 Background 後,padding失效的問題,只是在Android 4.4.4 和 4.4.2 的手機上遇到了。 網上搜索了下,說是 4.4 系統里的一個bug,解決方法就是 在動態設置 Background 後,重新設置 padding。 ...
  • weex旨在“一次撰寫,多端使用”,意思是,用weex寫的頁面,不論是Android還是iOS甚至web端都可以使用,這樣的話就可以極大的降低開發成本, weex其實就是寫的一個類似於h5的頁面(js編寫),寫完之後將vue文件編譯、部署到Nginx伺服器上(Nginx伺服器後面會講到),這時候在... ...
  • 插件介紹 這是一個我在寫以前的項目的途中發現的一個國人寫的jQuery圖像裁剪插件,當時想實現用戶資料的頭像上傳功能,並且能夠預覽圖片,和對圖片進行簡單的裁剪、旋轉,花了不少時間才看到了這個插件,感覺功能挺全面,代碼實現起來也挺簡單,再加上用的是Bootstrap,對移動端操作也有適配,於是就用了。 ...
  • 對於剛開始學習js的同學,強烈推薦直接使用chrome developer mode,超級方便。 隨便打開一個網頁,開啟開發者模式即可寫js代碼,不用新建html和js文件即可看到自己寫的js代碼的結果 如下: 甚至連console.log();都可以不用就能看到輸出結果,是不是很方便。 開啟開發者 ...
  • <html><head> <meta charset="utf-8"> <title>Swiper輪播</title></head><body> <div class="swiper-container" id="Exhibition-swiper" style="width:800px"> <di ...
  • 這是繼前兩篇後的第三篇,這一章主要是說關於react裡面樣式的一些問題,這樣讓你頁面構建更加美觀。 ...
  • 一般元素在頁面所占的空間包括:magin border padding content。以前一直以為子元素設置百分比寬高都是以父元素的content值為基準計算的。但是當子元素的position不同時,卻是不同的結果。 demo 用如下小demo測試: 效果如下: 子元素以父元素的content寬度 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...