js实现文本框支持加减运算的方法


Posted in Javascript onAugust 19, 2015

本文实例讲述了js实现文本框支持加减运算的方法。分享给大家供大家参考。具体如下:

这是一个网页表单效果,让表单内的文本框支持加减运算,不过你要按正确的运算式输入,要不然它没有那么智能哦,比如输入1+5,文本框旁边会显示计算结果,这要归功于JavaScript的功能。

运行效果截图如下:

js实现文本框支持加减运算的方法

在线演示地址如下:

具体代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>支持加减运算的文本框</title>
<meta http-equiv="content-type" content="text/html;charset=gb2312">
<style type="text/css">
body{color:#000;font-size:14px;font-family:Verdana,Arial,Helvetica,sans-serif,"宋体";}
input{border-style:solid;border-color:#868275;background-color:#f9f9f9;border-width:1px;color:#505050;vertical-align:middle;}
</style>
<script language=javascript>
function FloatAdd(arg1,arg2){
 var r1,r2,m;
 try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}
 try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}
 m=Math.pow(10,Math.max(r1,r2))
 return (arg1*m+arg2*m)/m
}
function FloatSubtr(arg1,arg2){
 return FloatAdd(arg1,-arg2);
}
function IsMoney(Money){
 if(/^[\d|+|.|-]+$/.test(Money)) return true;
 return false;
}
function result(){
 str=document.getElementById("buy").value;
 if(!(IsMoney(str))){
  document.getElementById("amount").innerHTML ="无效金额";
  return false;
 }
 var len=str.length,money=0,Num=0;
 var NumStr="",ctrlflag="x",cflag=0;
 for(var i=0;i<len; i++){
  c= str.charAt(i);
  if((c=="+")||(c=="-")){
   if(i+1<len){
    if ((str.charAt(i+1)=="+")||(str.charAt(i+1)=="-")) continue;
   }
   if((NumStr!="")&&(isNaN(NumStr))){
    if(isNaN(NumStr)){
     document.getElementById("amount").innerHTML ="输入无效金额";
     return false;
    }
   }
   if(NumStr!=""){
   //alert("i:"+i+"NumStr:"+NumStr);
    if ((ctrlflag=="+")||(ctrlflag=="x")){
     Num=parseFloat(NumStr);
     //alert(ctrlflag+"money:"+money+"Num:"+Num);
     money=FloatAdd(money,Num);
     NumStr="";
     Num=0;
     ctrlflag=c;
    }
    else{
     //alert(money+"里面减了"+NumStr);
     Num=parseFloat(NumStr);
     money=FloatSubtr(money,Num);
     NumStr="";
     Num=0;
     ctrlflag=c;
    }
   }
   else{
    ctrlflag=c;
   }
  continue;
  }
  else{
   NumStr=NumStr+""+c;
  }
 }
 if((NumStr!="")&&(isNaN(NumStr))){
  if (isNaN(NumStr)){
   document.getElementById("amount").innerHTML ="无效金额"+NumStr;
   return false;
  }
 }
 if((ctrlflag=="-")&&(NumStr!="")){
  Num=parseFloat(NumStr); 
  money=FloatSubtr(money,Num);
 }
 if(((ctrlflag=="+")||(ctrlflag=="x"))&&((NumStr!=""))){
  Num=parseFloat(NumStr);
  money=FloatAdd(money,Num);
 }
 document.getElementById("amount").innerHTML =money;
}
</script>
</head>
<body>
请输入加减计算式:<input id="buy" name="buy" maxlength="30" type="text" onkeyup="javascript:result();">
<span id="amount"></span>
</body>
</html>

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
判断JS对象是否拥有某种属性的两种方式
Dec 02 Javascript
单击某一段文字改写文本颜色
Jun 06 Javascript
全面解析Bootstrap图片轮播效果
Dec 03 Javascript
js实现滚动条滚动到页面底部继续加载
Dec 19 Javascript
AngularJS 与Bootstrap实现表格分页实例代码
Oct 14 Javascript
微信小程序(三):网络请求
Jan 13 Javascript
vue实现2048小游戏功能思路详解
May 09 Javascript
jQuery简单实现的HTML页面文本框模糊匹配查询功能完整示例
May 09 jQuery
手把手教你vue-cli单页到多页应用的方法
May 31 Javascript
ES6之Proxy的get方法详解
Oct 11 Javascript
JS实现吸顶特效
Jan 08 Javascript
解决Vue-cli3没有vue.config.js文件夹及配置vue项目域名的问题
Dec 04 Vue.js
JS实现方向键切换输入框焦点的方法
Aug 19 #Javascript
纯CSS3代码实现滑动开关效果
Aug 19 #Javascript
js实现input框文字动态变换显示效果
Aug 19 #Javascript
jQuery左侧大图右侧小图焦点图幻灯切换代码分享
Aug 19 #Javascript
js实现Form栏显示全格式时间时钟效果代码
Aug 19 #Javascript
easyui Droppable组件实现放置特效
Aug 19 #Javascript
js实现简单的联动菜单效果
Aug 19 #Javascript
You might like
PHP测试程序运行时间的类
2012/02/05 PHP
PHP三元运算的2种写法代码实例
2014/05/12 PHP
ThinkPHP使用Smarty第三方插件方法小结
2016/03/19 PHP
PHP屏蔽关键字实现方法
2016/11/17 PHP
PHP基于redis计数器类定义与用法示例
2018/02/08 PHP
php对微信支付回调处理的方法
2018/08/23 PHP
IE与FireFox的兼容性问题分析
2007/04/22 Javascript
Prototype中dom对象方法汇总
2008/09/17 Javascript
编写针对IE的JS代码两种编写方法
2013/01/30 Javascript
js控制不同的时间段显示不同的css样式的实例代码
2013/11/04 Javascript
JS获取文本框,下拉框,单选框的值的简单实例
2014/02/26 Javascript
jQuery中get和post方法传值测试及注意事项
2014/08/08 Javascript
原生JavaScript生成GUID的实现示例
2014/09/05 Javascript
jQuery中:input选择器用法实例
2015/01/03 Javascript
jquery实现清新实用的网页菜单效果
2015/08/28 Javascript
javascript弹出窗口实现代码
2015/11/12 Javascript
Bootstrap实现响应式导航栏效果
2015/12/28 Javascript
jQuery Ajax 异步加载显示等待效果代码分享
2016/08/01 Javascript
webpack独立打包和缓存处理详解
2017/04/03 Javascript
从零开始学习Node.js系列教程之基于connect和express框架的多页面实现数学运算示例
2017/04/13 Javascript
微信小程序 空白页重定向解决办法
2017/06/27 Javascript
JavaScript设计模式之单例模式原理与用法实例分析
2018/07/26 Javascript
在vue中安装使用vux的教程详解
2018/09/16 Javascript
javascript中关于类型判断的一些疑惑小结
2018/10/14 Javascript
Vue编写可显示周和月模式的日历 Vue自定义日历内容的显示
2019/06/26 Javascript
webpack常用构建优化策略小结
2019/11/21 Javascript
element 动态合并表格的步骤
2020/12/31 Javascript
python入门教程 python入门神图一张
2018/03/05 Python
Python实现OpenCV的安装与使用示例
2018/03/30 Python
caffe binaryproto 与 npy相互转换的实例讲解
2018/07/09 Python
简单了解Pandas缺失值处理方法
2019/11/16 Python
酒店前台接待岗位职责
2013/12/03 职场文书
幼儿园教育教学反思
2014/01/31 职场文书
经销商年会策划方案
2014/05/29 职场文书
学雷锋活动总结报告
2014/06/26 职场文书
KTV员工管理制度
2015/08/06 职场文书