页面文件

<#-- 页头 -->
<#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(二级务必提交书面和数字到数字中国)的更多相关文章

  1. bootbox.js

    bootbox:一个弹出框插件,官网看一下例子就好了:http://bootboxjs.com/examples.html 目前来说应该只要调用bootbox.js就可以了,没有css的问题 1.有最 ...

  2. 弹出框二 之 bootbox.js

    1.可以通过Nuget下载 2.引入 jquery bootstrap bootbox.js 3.使用 $(function () { //bootbox.alert("确认删除" ...

  3. js ajax post提交 ie和火狐、谷歌提交的编码不一致,导致中文乱码

    今天遇到一个问题找了很久发现: 使用js ajax post提交 ie和火狐.谷歌提交的编码不一致,导致中文乱码 //http://www.cnblogs.com/QGC88 $.ajax({ url ...

  4. bootbox.js [v4.2.0]设置确认框 按钮语言为中文

    Bootbox.js (http://bootboxjs.com/)是一个小型的 JavaScript 库用来创建简单的可编程对话框,基于 Twitter 的 Bootstrap 开发. 弹出确认框方 ...

  5. js循环POST提交添加辅助单位

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...

  6. 下拉的DIV+CSS+JS二级树型菜单

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. bootbox.js官方文档

    简介 Bootbox.js是一个小型的JavaScript库,基于Bootstrap模态框开发,用于创建可编程的对话框. 不像原生的alert等对话框,所有的Bootstrap模态框生成的都是非阻塞事 ...

  8. JS实现异步提交

    什么是XMLHttpRequest? XMLHttpRequest对象用于在后台与服务器交换数据 XMLHttpRequst的作用 在不重新加载页面的情况下更新网页 在页面已加载后从服务器请求数据 在 ...

  9. bootbox.js官方文档中文版

    bootbox.js官方文档中文版简介:Bootbox.js是一个小型的JavaScript库,基于Bootstrap模态框开发,用于创建可编程的对话框. 不像原生的alert等对话框,所有的Boot ...

随机推荐

  1. 用 C++ 标准模板库(STL)的 vector 实现二叉搜索树(BST)

    本文由 Justme0翻译自 Code Project 转载请参见文章末尾处的要求. 介绍 众所周知,要建一棵树,我们需要关注它的内存分配与释放.为了避开这个问题,我打算用C++ STL(vector ...

  2. 自编Ps教程—我的ps图片赞赏

    上篇讲述了主要的ps概念和操作,这里不再讲述了,主要的操作学好了,其它的都简单,下面我会把我闲暇时间天马行空的小作品上穿,以供大家闲暇时间或者工作累了的时候赞赏! 以后还会在这里上传哦!喜欢就收藏吧! ...

  3. Node.js: What is the best "full stack web framework" (with scaffolding, MVC, ORM, etc.) based on Node.js / server-side JavaScript? - Quora

    Node.js: What is the best "full stack web framework" (with scaffolding, MVC, ORM, etc.) ba ...

  4. Struts2第一个工程helloStruts极其基本配置

    前面已经准备好了Struts-2.3.15,现在就可以直接搭建Struts2的工程了.前面http://blog.csdn.net/huangchnegdada/article/details/917 ...

  5. RequireJS学习资料

    RequireJS学习资料汇总   入门系列 [1]阮一峰 RequireJS用法 [2]RequireJS入门指南 文档系列 [1]RequireJS中文文档 [2]RequireJS英文文档 代码 ...

  6. Working with forms

    翻译 Django文档 Version 1.5 https://docs.djangoproject.com/en/1.5/topics/forms Working with forms 关于此文章: ...

  7. Compass用法指南

    Compass用法指南   Sass是一种"CSS预处理器",可以让CSS的开发变得简单和可维护.但是,只有搭配Compass,它才能显出真正的威力. 本文介绍Compass的用法 ...

  8. spring原拦截器配置与新命名空间mvc:interceptors配置拦截器对照与注意事项

    原先,我们是这么配置拦截器的 <bean id="openSessionInViewInterceptor"class="org.springframework.o ...

  9. Socket编程实践(12) --UDP编程基础

    UDP特点 无连接,面向数据报(基于消息,不会粘包)的传输数据服务; 不可靠(可能会丢包, 乱序, 反复), 但因此普通情况下UDP更加高效; UDP客户/服务器模型 UDP-API使用 #inclu ...

  10. 每日回顾Shell —cat,tail,head

    Shell中常常会用到cat命令.可是总是不是特别清楚: cat命令的用途是连接文件或标准输入并打印. 这个命令经常使用来显示文件内容.或者将几个文件连接起来显示.或者从标准输入读取内容并显示,它常与 ...