[原] 自定義條件公式和計算公式的動態配置計算器的示例

 先上效果圖以下:
javascript

一、本公式自定義配置計算器的實現基於DataTable.Compute()的用法,該函數用法詳細參考文檔;本示例支持條件公式、計算公式的配置css

二、界面樣式java

 1 <style type="text/css">
 2         .p {
 3             width: 40px;
 4             height: 40px;
 5             background-color: green;
 6             border: 1px solid #0e0808;
 7             float: left;
 8             text-align: center;
 9             line-height: 40px;
10             color: white;
11             font-weight: bold;
12             cursor: pointer;
13         }
14         .pblack {
15             width: 100px;
16         }
17         .param {
18             width: 90%;
19             height: 40px;
20             background-color: green;
21             border: 1px solid #0e0808;
22             float: left;
23             text-align: center;
24             line-height: 40px;
25             color: white;
26             font-weight: bold;
27             cursor: pointer;
28         }
29     </style>

三、界面腳本數據庫

  1 <script type="text/javascript">
  2 
  3         var KeyList = new Array();//公式對外文本
  4         var KeyValueList = new Array();//公司的對內編碼
  5 
  6         jQuery(document).ready(function () {
  7 
  8             //選公式
  9             jQuery(".p").click(function () {
 10 
 11                 jQuery("#TextAreaFormula").focus();//
 12                 
 13                 var inputText = jQuery(this).text();//
 14                 var inputValue = jQuery(this).data("value");//
 15 
 16                 //一、空格鍵
 17                 if (inputText.length == 0 || inputText == "") {
 18                     inputText = " ";
 19                     inputValue = " ";
 20                 }
 21 
 22                 //非數字鍵
 23                 if ("0123456789".indexOf(String(inputText)) < 0) {
 24                     if ("C←".indexOf(String(inputText)) >= 0) {
 25                         switch (String(inputText)) {
 26                             case "C"://清空鍵
 27                                 KeyList = [];
 28                                 KeyValueList = [];
 29 
 30                                 jQuery("#TextAreaFormula").val("");
 31                                 jQuery("#TextAreaFormulaCode").val("");
 32 
 33                                 jQuery("#TextAreaFormula").focus();
 34                                 return;
 35                                 break;
 36                             case ""://退格鍵
 37                                 //
 38                                 KeyList.pop();
 39                                 var strChanged = "";
 40                                 for (var i = 0; i < KeyList.length; i++) {
 41                                     strChanged += String(KeyList[i]);
 42                                 }
 43                                 jQuery("#TextAreaFormula").val(strChanged.trimEnd());
 44                                 jQuery("#TextAreaFormula").focus();
 45 
 46                                 //
 47                                 KeyValueList.pop();
 48                                 var strvalueCharged = "";
 49                                 for (var i = 0; i < KeyValueList.length; i++) {
 50                                     strvalueCharged += String(KeyValueList[i]);
 51                                 }
 52                                 jQuery("#TextAreaFormulaCode").val(strvalueCharged.trimEnd());
 53                                 return;
 54                                 break;
 55                             //case "And":
 56                             //    inputText = " " + "&&" + " ";
 57                             //    inputValue = " " + "&&" + " ";
 58                             //    break;
 59                             //case "Or":
 60                             //    inputText = " " + "||" + " ";
 61                             //    inputValue = " " + "||" + " ";
 62                             //    break;
 63                             default:
 64                                 break;
 65                         }
 66                     }
 67                     else if ("." == String(inputText)) {
 68 
 69                     }
 70                     else { //非清空\退格\小數點鍵的其餘鍵
 71                         inputText = " " + inputText + " ";
 72                         inputValue = " " + inputValue + " ";
 73                     }
 74                 }
 75 
 76                 //數字和小數點-鍵
 77                 var HaveExistStr = jQuery("#TextAreaFormula").val();
 78                 jQuery("#TextAreaFormula").val(HaveExistStr + inputText);
 79                 KeyList.push(inputText);
 80                 jQuery("#TextAreaFormula").focus();
 81 
 82                 //數字和小數點-值
 83                 var HaveExistStrValue = jQuery("#TextAreaFormulaCode").val();
 84                 jQuery("#TextAreaFormulaCode").val(HaveExistStrValue + inputValue);
 85                 KeyValueList.push(inputValue);
 86 
 87             });
 88 
 89             //選參數
 90             jQuery(".param").click(function () {
 91                 jQuery("#TextAreaFormula").focus();
 92 
 93                 var inputText = jQuery(this).text();
 94                 var inputValue = jQuery(this).data("value");
 95                 inputText = " [" + inputText + "] ";
 96                 inputValue = " [" + inputValue + "] ";
 97 
 98                 var HaveExistStr = jQuery("#TextAreaFormula").val();
 99                 jQuery("#TextAreaFormula").val(HaveExistStr.trimEnd() + inputText);
100                 KeyList.push(inputText);
101                 jQuery("#TextAreaFormula").focus();
102 
103                 var HaveExistStrValue = jQuery("#TextAreaFormulaCode").val();
104                 jQuery("#TextAreaFormulaCode").val(HaveExistStrValue.trimEnd() + inputValue);
105                 KeyValueList.push(inputValue);
106 
107             });
108 
109         });
110 
111         //去除字符串尾部空格或指定字符   
112         String.prototype.trimEnd = function (s) {
113             s = (s ? s : "\\s");
114             s = ("(" + s + ")");
115             var reg_trimEnd = new RegExp(s + "*$", "g");
116             return this.replace(reg_trimEnd, "");
117         };
118 
119 
120     </script>

四、界面HTML源碼函數

 1     <form id="form1" runat="server">
 2         
 3         <div style="float:left;width:90%;border:1px solid #ff0000;margin:5px;padding:20px;">
 4             <table>
 5                 <tr>
 6                     <td colspan="2">
 7                         <textarea id="TextAreaFormula" cols="80" rows="2" style="float:left;width:680px;" readonly="readonly" runat="server"></textarea>
 8                         <input id="TextAreaFormulaCode" type="text" style="float:left;width:681px;" readonly="readonly" runat="server"/>
 9                     </td>
10                 </tr>
11                 <tr>
12                     <td style="width:100px;vertical-align:top;">
13                         <div class="param" data-value="BasicSalary">基本工資</div>
14                         <div class="param" data-value="OTDays">加班天數</div>
15                         <div class="param" data-value="LengthOfService">工齡</div>
16                     </td>
17                     <td style="width:280px;">
18                         <div class="p" data-value="(">(</div><div class="p" data-value=")">)</div>
19                         <div class="p" data-value="+">+</div><div class="p" data-value="-">-</div>
20                         <div class="p" data-value="*">*</div><div class="p" data-value="/">/</div>
21                         <div class="p" data-value="0">0</div><div class="p" data-value="1">1</div>
22                         <div class="p" data-value="2">2</div><div class="p" data-value="3">3</div>
23                         <div class="p" data-value="4">4</div><div class="p" data-value="5">5</div>
24                         <div class="p" data-value="6">6</div><div class="p" data-value="7">7</div>
25                         <div class="p" data-value="8">8</div><div class="p" data-value="9">9</div>
26                         <div class="p" data-value=">">></div><div class="p" data-value=">=">>=</div>
27                         <div class="p" data-value="=">=</div>
28                         <div class="p" data-value="<"><</div><div class="p" data-value="<="><=</div>
29                         <div class="p" data-value=".">.</div>
30                         <div class="p" data-value="And">And</div>
31                         <div class="p" data-value="Or">Or</div>
32                         <div class="p pblack" data-value=""></div>
33                         <div class="p" data-value="C">C</div>
34                         <div class="p" data-value="←"></div>
35                     </td>
36                 </tr>
37                 <tr>
38                     <td>
39                         
40                     </td>
41                     <td>
42                         <table>
43                             <tr>
44                                 <td>基本工資金額:</td>
45                                 <td>
46                                     <asp:TextBox ID="TextBoxBasicSalary" runat="server">2000</asp:TextBox>
47                                 </td>
48                             </tr>
49                             <tr>
50                                 <td>加班天數:</td>
51                                 <td><asp:TextBox ID="TextBoxOTDays" runat="server">20</asp:TextBox></td>
52                             </tr>
53                             <tr>
54                                 <td>工齡(年):</td>
55                                 <td><asp:TextBox ID="TextBoxLengthOfService" runat="server">10</asp:TextBox></td>
56                             </tr>
57                             <tr>
58                                 <td colspan="2">
59                                     <asp:Button ID="Button1" runat="server" Text="配置公式→輸入參數值→計算公式的結果" OnClick="Button1_Click" />
60                                 </td>
61                             </tr>
62                         </table>
63                         
64                         <br/>
65                         
66                         <br/>
67                         
68                         <br/>
69                         
70                     </td>
71                 </tr>
72             </table>
73         </div>
74     </form>

 

五、後臺代碼this

 1     /// <summary>
 2     /// 計算
 3     /// </summary>
 4     public class ParamModel {
 5 
 6         /// <summary>
 7         /// 基本工資
 8         /// </summary>
 9         public decimal BasicSalary { get; set; }
10 
11         /// <summary>
12         /// 加班天數
13         /// </summary>
14         public decimal OTDays { get; set; }
15 
16         /// <summary>
17         /// 工齡
18         /// </summary>
19         public decimal LengthOfService { get; set; }
20 
21         //還可繼續擴充,也能夠考慮使用動態類
22     }
 1         /// <summary>
 2         /// 實例源碼
 3         /// </summary>
 4         /// <param name="sender"></param>
 5         /// <param name="e"></param>
 6         protected void Button1_Click(object sender, EventArgs e)
 7         {
 8             var ParamModel = new ParamModel();
 9             ParamModel.BasicSalary = Convert.ToDecimal(this.TextBoxBasicSalary.Text ?? "0");
10             ParamModel.OTDays = Convert.ToDecimal(this.TextBoxOTDays.Text ?? "0");
11             ParamModel.LengthOfService = Convert.ToDecimal(this.TextBoxLengthOfService.Text ?? "0");
12 
13 
14             DataTable eval = new DataTable();
15             var formulaText = this.TextAreaFormulaCode.Value;//公式
16             var Str = formulaText;
17             var StrParam = string.Empty;
18             foreach (var PropertyInfo in ParamModel.GetType().GetProperties())
19             {
20                 if (formulaText.IndexOf("[" + PropertyInfo.Name + "]") >= 0)
21                 {
22                     Str = Str.Replace(("[" + PropertyInfo.Name + "]"), "(" + PropertyInfo.GetValue(ParamModel, null).ToString() + ")");//將表達式中的參數Code替換爲實際的值
23                     StrParam += string.Format("[{0}]={1},", PropertyInfo.Name, PropertyInfo.GetValue(ParamModel, null).ToString());//表達式中各參數的值
24                 }
25             }
26             object result = null;
27             try
28             {
29                 result = eval.Compute(Str, "");//文本表達式的運行結果
30             }
31             catch(Exception ex)
32             {
33                 Response.Write("公式配置有誤,請從新配置!具體錯誤:" + ex.Message+"<br/>");
34                 return;
35             }
36             StrParam = StrParam.TrimEnd(',');//各參數的值
37             Response.Write(string.Format(
38                 "公式含義:{4}<br/>"
39                 + "公式編碼:{0}<br/>"
40                 + "參數取值:<br/>"
41                 + "{3}<br/>"
42                 + "公式解析:{1} <br/>"
43                 + "計算結果:{2}<br/>",
44                 formulaText,
45                 Str,
46                 Convert.ToString(result),
47                 StrParam,
48                 this.TextAreaFormula.Value));
49 
50         }


六、擴展編碼

在此基礎上能夠進一步發揮的空間很大spa

》結合存儲設計如數據庫等,參數能夠動態加載參數;prototype

》諸如參數自定義,自定義的參數再次被用做新參數的配置,參數嵌套使用,能夠配置出強大而複雜的計算公式以及條件公式設計

》結合存儲設計再結合C#的動態類,能夠使得參數對應的類也動態化;

》固然簡單級別的計算並不徹底須要面向對象的類的設計,徹底使用存儲設計,全部參數能夠徹底依賴如數據庫或其餘存儲方式如XML等來提供

相關文章
相關標籤/搜索