使用bootbox.js(二级务必提交书面和数字到数字中国)
页面文件
<#-- 页头 -->
<#assign currNav = "deposit">
<#assign title="网校充值">
<#include "/root/commons/header.ftl"> <div class="container"> <form id="depositForm" name="depositForm" role="form" action="/root/depositlog/${schoolId}/deposit" method="post">
<div class="form-group">
<label for="schoolId">网校ID</label>
<input type="text" class="form-control" id="schoolId" name="schoolId" placeholder="比如。udemy" value="${school.schoolId!''}" readonly="readonly">
<p class="help-block">全局唯一,不能和其它网校的ID同样</p>
</div>
<div class="form-group">
<label for="name">网校名称</label>
<input type="text" class="form-control" id="name" name="name" placeholder="请填写网校名称" value="${school.name!''}" readonly="readonly">
</div> <div class="form-group">
<label for="duration">充值分钟数 <span id="chinaText" class="text-muted text-sm" style="margin-left:60px;font-size:12px;"> </span></label>
<input type="number" class="form-control" id="duration" name="duration" placeholder="">
<p class="help-block">单位:分钟</p>
</div>
<div class="form-group">
<label for="amount">充值金额 <span id="moneyText" class="text-muted text-sm" style="margin-left:60px;font-size:12px;"> </span></label>
<input type="text" class="form-control" id="amount" name="amount" placeholder="">
<p class="help-block">单位:元</p>
</div>
<div class="form-group">
<label for="note">备注</label>
<input type="text" class="form-control" id="note" name="note" placeholder="">
</div> </form> <button id="submitBtn" class="btn btn-primary">提交充值数据</button> </div> <!-- /container --> <#-- 页脚開始 -->
<#include "/root/commons/footerBegin.ftl"> <script src="/resources/js/bootbox.js"></script> <script>
//在输入框内容变化的时候触发change
$("#duration").on('input',function(e){
var value=$("#duration").val(); $.get("/root/depositlog/input/change",{number:value},function(data){
$("#chinaText").text(data+" 分钟");
});
}); $("#amount").on('input',function(e){
var value=$("#amount").val(); $.get("/root/depositlog/input/change",{number:value},function(data){
$("#moneyText").text(data+" 元");
});
}); $("#submitBtn").click(function(){
var schoolId=$("#schoolId").val();
var name=$("#name").val();
var duration=$("#duration").val();
var amount=$("#amount").val(); bootbox.dialog({
message: "<div id='schoolName'>网校名称:<span>"+name+"</span><span style='margin-left:10px'>schoolId-("+schoolId+")</span></div>"+
"<div>充值时长:<span>"+duration+" 分钟</span></div>"+
"<div>充值金额:<span>"+amount+" 元</span></div>",
title: "充值确认",
buttons: {
success: {
label: "确定",
className: "btn-success",
callback: function() {
document.depositForm.submit();
}
},
danger: {
label: "取消",
className: "btn-danger",
callback: function() {
return;
}
}
}
}); });
</script> <#-- 页脚结束 -->
<#include "/root/commons/footerEnd.ftl">
推断仅仅有是数字字符串才发送
$("#duration").on('input',function(e){
var value=$("#duration").val();
//alert($.isNumeric(value));
if($.isNumeric(value)){
$("#mistakeText").html("");
$.get("/springmvc/input/change",{number:value},function(data){
$("#chinaText").html(data+"分钟");
});
}else{
$("#mistakeText").html("请输入数字!");
}
});
Java类文件
package com.school.web.controller.root; import java.math.BigDecimal;
import java.nio.charset.Charset;
import java.util.Date;
import java.util.List; import javax.servlet.http.HttpServletRequest; import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.ServletRequestUtils;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.servlet.ModelAndView; import com.school.business.DepositLogManager;
import com.school.business.SchoolManager;
import com.school.domain.DepositLog;
import com.school.domain.Root;
import com.school.domain.School;
import com.school.stereotype.YesNoStatus;
import com.school.util.Constants; /**
* 充值管理的控制器。
*/
@Controller("rootDepositManagementController")
@RequestMapping("/root/depositlog")
public class DepositManagementController extends AbstractRootController { private static final Logger LOG = LoggerFactory.getLogger(DepositManagementController.class); @Autowired
private SchoolManager schoolManager; @Autowired
private DepositLogManager depositLogManager; /**
* 充值表单。
*/
@RequestMapping(value = "/{schoolId}/deposit", method = RequestMethod.GET)
public ModelAndView depositForm(@PathVariable String schoolId, HttpServletRequest request) { // 网校信息
School school = schoolManager.getSchool(schoolId); ModelAndView mav = this.createModelAndView(request);
mav.setViewName("root/depositLog/deposit");
mav.addObject("schoolId", schoolId);
mav.addObject("school", school);
return mav;
} /**
* 处理充值。
*/
@RequestMapping(value = "/{schoolId}/deposit", method = RequestMethod.POST)
public @ResponseBody String depositPost(@PathVariable String schoolId, HttpServletRequest request) { int duration = ServletRequestUtils.getIntParameter(request, "duration", 0);// 时长分钟数。单位:分钟
double amount = ServletRequestUtils.getDoubleParameter(request, "amount", 0);// 价格
String tradingNote = ServletRequestUtils.getStringParameter(request, "note", null); // 备注 if (duration <= 0) {
return "invalid duration";
} if (amount < 0) {
return "invalid amount";
} // 当前管理员信息
Root root = (Root) (request.getSession().getAttribute(Constants.ROOT_SESSION_NAME)); // 交易名称
String tradingName = schoolId + "充值" + duration + "。费用:" + amount + "元"; // 充值信息
DepositLog depositLog = new DepositLog();
depositLog.setSchoolId(schoolId);
depositLog.setTradingName(tradingName);
depositLog.setTradingNote(tradingNote);
depositLog.setDuration(duration);
depositLog.setAmount(BigDecimal.valueOf(amount));
depositLog.setOperator(root.getNickname());
depositLog.setStatus(YesNoStatus.YES.getValue());
depositLog.setDateAdded(new Date());
depositLog.setLastModified(new Date()); int rows = depositLogManager.addDepositLog(depositLog);
LOG.info(tradingName + "。处理结果:" + rows); return "success";
} /**
* 查看近期100条充值记录。
*/
@RequestMapping("/list")
public ModelAndView depositLogs(HttpServletRequest request) {
// 查询充值记录
List<DepositLog> depositLogs = depositLogManager.getDepositLogs(); ModelAndView mav = this.createModelAndView(request);
mav.setViewName("root/depositLog/list");
mav.addObject("depositLogs", depositLogs);
return mav;
} /**
* 将数字转换成中文数字
* @author Prosper
* @throws UnsupportedEncodingException
*/
@RequestMapping(value="/input/change", method = {RequestMethod.POST,RequestMethod.GET})
public ResponseEntity<String> getCNint(HttpServletRequest request){
HttpHeaders headers = new HttpHeaders();
MediaType mediaType = new MediaType("text", "plain", Charset.forName("UTF-8"));
//MediaType mediaType = new MediaType("application", "json", Charset.forName("UTF-8"));
headers.setContentType(mediaType);
//HttpStatus Yes=HttpStatus.OK; String str = request.getParameter("number"); if("".equals(str) && str==null){
return new ResponseEntity<String>("no", headers, HttpStatus.OK);
}else{
Integer number = Integer.parseInt(str);
String ri=intToZH(number);
return new ResponseEntity<String>(ri, headers, HttpStatus.OK);
} } public String intToZH(int i){
String[] zh = {"零", "一", "二", "三", "四", "五", "六", "七", "八", "九"};
String[] unit = {"", "十", "百", "千", "万", "十", "百", "千", "亿", "十"}; String str = "";
StringBuffer sb = new StringBuffer(String.valueOf(i));
sb = sb.reverse();
int r = 0;
int l = 0;
for (int j = 0; j < sb.length(); j++)
{
/**
* 当前数字
*/
r = Integer.valueOf(sb.substring(j, j+1)); if (j != 0)
/**
* 上一个数字
*/
l = Integer.valueOf(sb.substring(j-1, j)); if (j == 0)
{
if (r != 0 || sb.length() == 1)
str = zh[r];
continue;
} if (j == 1 || j == 2 || j == 3 || j == 5 || j == 6 || j == 7 || j == 9)
{
if (r != 0)
str = zh[r] + unit[j] + str;
else if (l != 0)
str = zh[r] + str;
continue;
} if (j == 4 || j == 8)
{
str = unit[j] + str;
if ((l != 0 && r == 0) || r != 0)
str = zh[r] + str;
continue;
}
}
return str;
} }
版权声明:本文博客原创文章。博客,未经同意,不得转载。
使用bootbox.js(二级务必提交书面和数字到数字中国)的更多相关文章
- bootbox.js
bootbox:一个弹出框插件,官网看一下例子就好了:http://bootboxjs.com/examples.html 目前来说应该只要调用bootbox.js就可以了,没有css的问题 1.有最 ...
- 弹出框二 之 bootbox.js
1.可以通过Nuget下载 2.引入 jquery bootstrap bootbox.js 3.使用 $(function () { //bootbox.alert("确认删除" ...
- js ajax post提交 ie和火狐、谷歌提交的编码不一致,导致中文乱码
今天遇到一个问题找了很久发现: 使用js ajax post提交 ie和火狐.谷歌提交的编码不一致,导致中文乱码 //http://www.cnblogs.com/QGC88 $.ajax({ url ...
- bootbox.js [v4.2.0]设置确认框 按钮语言为中文
Bootbox.js (http://bootboxjs.com/)是一个小型的 JavaScript 库用来创建简单的可编程对话框,基于 Twitter 的 Bootstrap 开发. 弹出确认框方 ...
- js循环POST提交添加辅助单位
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...
- 下拉的DIV+CSS+JS二级树型菜单
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- bootbox.js官方文档
简介 Bootbox.js是一个小型的JavaScript库,基于Bootstrap模态框开发,用于创建可编程的对话框. 不像原生的alert等对话框,所有的Bootstrap模态框生成的都是非阻塞事 ...
- JS实现异步提交
什么是XMLHttpRequest? XMLHttpRequest对象用于在后台与服务器交换数据 XMLHttpRequst的作用 在不重新加载页面的情况下更新网页 在页面已加载后从服务器请求数据 在 ...
- bootbox.js官方文档中文版
bootbox.js官方文档中文版简介:Bootbox.js是一个小型的JavaScript库,基于Bootstrap模态框开发,用于创建可编程的对话框. 不像原生的alert等对话框,所有的Boot ...
随机推荐
- hdu4223(dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4223 由于n范围较小,完全可暴力... #include <cstdio> #includ ...
- Hibernate 配置详解(7)
hibernate.order_updates: Hibernate文档中提到,该配置用于在刷新一级缓存,提交UPDATE的时候,按照每类对象的主键顺序排序后再提交,可以在高并发情况下减少事务死锁的可 ...
- Android自己定义组件系列【2】——Scroller类
在上一篇中介绍了View类的scrollTo和scrollBy两个方法,对这两个方法不太了解的朋友能够先看<自己定义View及ViewGroup> scrollTo和scrollBy尽管实 ...
- hdu1059(多重背包)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1059 题意 : 按顺序读入一些列数,所对应的序列代表价值,数值代表个数(如a[5]=6 ,代表价值为五 ...
- iOS_UIButton 简单操作
UIButton 风格 typedef NS_ENUM(NSInteger, UIButtonType) { UIButtonTypeCustom = 0, // no button type UIB ...
- SE 2014年4月29日
交换网络中有vlan1 到20个vlan,要求使用MSTP技术实现vlan的负载分担. SW2为实例1(vlan1-vlan10)的主根,SW3为备根 SW3为实例2(vlan11-vlan20)的主 ...
- 微通道对接ERP、CRM、OA、HR、SCM、PLM和其他管理系统解决方案
公司现有ERP.CRM.OA.HR.SCM.PLM等管理系统的对接微信公共平台服务 方法1:开放接口 企业开放现有系统数据接口给第三方,或由第三方开发数据接口对接微信公众平台 方法2:获取数据库 企业 ...
- VBoxGuestAdditions.iso下载地址
http://download.virtualbox.org/virtualbox/4.1.2/VBoxGuestAdditions_4.1.2.iso 其它版本号可依次判断..
- 安装pygame
pygame的安装 我们首先要去到:http://www.pygame.org/download.shtml 下载我们所需要的软件包: 我选择的是:pygame-1.9.2a0.win32-py3.2 ...
- .NET 单点登录
<appSettings> <!--是否启用单点登录接口--> <add key="IsStartCas" value="f ...