以下是本人原创,如若转载和使用请注明转载地址。本博客信息切勿用于商业,可以个人使用,若喜欢我的博客,请关注我,谢谢!少帅的博客
使用Ext实现简单计算器,网页版实现
1、页面部分calculator.jsp

 
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>基于ExtJS的计算器</title>
    
    <link rel="stylesheet" type="text/css" href="<%=basePath%>js/resources/css/ext-all.css">
    <script type="text/javascript" src="<%=basePath%>js/ext-debug.js"></script>
    <script type="text/javascript" src="<%=basePath%>js/ext-all-debug.js"></script>
    <script type="text/javascript" src="<%=basePath%>js/jquery-1.9.0.js"></script>
    <script type="text/javascript">
    $(document).ready(function(){
    //$("#block").hide();
        $("#btn").click(function(){
            $("#block").toggle();
        });
    });
    Ext.onReady( function () {
    
        Ext.create("Ext.Button", {
            renderTo: Ext.get("btn"),
            text: "计算器",
            allowDepress: true,     //是否允许按钮被按下的状态
            enableToggle: true,     //是否允许按钮在弹起和按下两种状态中切换
            id: "bt1"
        });
      
         new Ext.dd.DDProxy('block');//定义面板可以任意拖动
             //Ext.Msg.alert('提示', '执行方法 Ext.onReady()');//测试ext能否使用
             var  calPanel =  new  Ext.panel.Panel({ //定义面板
                title: '计算器' , //标题
                renderTo:'block', //将显示指向页面的body
                bodyPadding:5, //设置间隔
                width:270, //面板宽度
                closable:true,//定义面板的关闭按钮,默认是false
                layout:{
                    type: 'table' ,
                    columns:5 //设置表格布局默认列数为4列
                },
                frame: true ,
                tbar:[
                     '公式:' ,
                     new  Ext.form.field.Text({
                        id: 'expression' ,
                        readOnly: true ,
                        style: 'text-align:right'
                    }),
                     '=' ,
                     new  Ext.form.field.Text({
                        id: 'result' ,
                        width:60
                    })
                ],
                defaultType: 'button' ,
                defaults:{
                    minWidth:50,
                    handler:btnClick
                },
                items:[  //定义按钮
                    {text: '1' ,symbol: '1' },
                    {text: '2' ,symbol: '2' },
                    {text: '3' ,symbol: '3' },
                    {text: '(' ,symbol: '(' },
                    {text: ')' ,symbol: ')' },
                    {text: '4' ,symbol: '4' },
                    {text: '5' ,symbol: '5' },
                    {text: '6' ,symbol: '6' },
                    {text: '+' ,symbol: '+' },
                    {text: '-' ,symbol: '-' },
                    {text: '7' ,symbol: '7' },
                    {text: '8' ,symbol: '8' },
                    {text: '9' ,symbol: '9' },
                    {text: '*' ,symbol: '*' },
                    {text: '/' ,symbol: '/' },
                    {text: '0' ,symbol: '0' },
                    {text: '.' ,symbol: '.' },
                    {text: '=' ,symbol: '=' },
                    {text: 'C' ,symbol: 'clear' },
                    {text: 'back' ,symbol: 'back' }
                ]
            })
             var  expression = Ext.getCmp( 'expression' ); //取得id为expression的组件
             var  result = Ext.getCmp( 'result' ); //取得id为result的组件
             function  btnClick(btn){  //定义按钮事件
                 var  oldValue = expression.getValue();  //得到输入的值
                 if (btn.symbol ==  'back' ){  //如果选择后退键
                    oldValue = oldValue.subString(0,oldValue.length - 1);
                } else   if (btn.symbol ==  'clear' ){ //如果选择呢清除键
                    oldValue = '' ;
                    result.setValue( '' );
                } else   if (btn.symbol ==  '=' ){ //如果选择等于键
                    calculate();
                } 
                //else   if (btn.symbol ==  '.' ){ //如果选择小数点
                     //if (oldValue.indexOf( '.' ) != -1){
                       //  return ;
                    //}
                //} 
                else  {
                    oldValue += btn.symbol;
                }
                expression.setValue(oldValue);
            }
            
             function  calculate(){
                 var  str = expression.getValue();  //取得表达式的值
                 if (!Ext.isEmpty(str)){  //如果表达式的值不为空
                    Ext.Ajax.request({  //利用ajax异步调用
                        url: 'calAction.action' , //请求服务器的地址
                        method:'post',
                        params:{exp:str}, //请求参数
                        callback: function (options,success,response){ //回调函数
                             if (success){ //计算成功的话
                                result.setValue(response.responseText); //设置结果框的值
                            } else { //请求出错时,输出框显示erro r
                                result.setRawValue( 'error' );
                            }
                        }
                    })
                }
            }
        });  
    
    </script>
    
 
  </head>
  
  <body>
  <div id="btn" style="width: 20"></div>
  <div id="block" style="width: 270"></div>
  </body>

  </html>

页面形式如下:
 
 

Ext实现简单计算器的更多相关文章

  1. 1.C#WinForm基础制作简单计算器

    利用c#语言编写简单计算器: 核心知识点: MessageBox.Show(Convert.ToString(comboBox1.SelectedIndex));//下拉序号 MessageBox.S ...

  2. 菜鸟学Android编程——简单计算器《一》

    菜鸟瞎搞,高手莫进 本人菜鸟一枚,最近在学Android编程,网上看了一些视频教程,于是想着平时手机上的计算器应该很简单,自己何不尝试着做一个呢? 于是就冒冒失失的开撸了. 简单计算器嘛,功能当然很少 ...

  3. PAT 06-1 简单计算器

    想看一般简单计算器实现的看客不好意思了,这不是你想要点东西,此处题设为“只能进行加减乘除”.“都是整数”.”优先级相同“和"从左到右".此题来自PAT(http://www.pat ...

  4. php大力力 [005节] php大力力简单计算器001

    2015-08-22 php大力力005. php大力力简单计算器001: 上网看视频,看了半天,敲击代码,如下: <html> <head> <title>简单计 ...

  5. PHP实现简单计算器

    <!--简单的计算器--> <!DOCTYPE html> <html> <head> <title>PHP实现简单计算器</titl ...

  6. c#部分---网吧充值系统;简易的闹钟;出租车计费;简单计算器;对战游戏;等额本金法计算贷款还款利息等;随机生成10个不重复的50以内的整数;推箱子;

    网吧充值系统namespace ConsoleApplication1 { class Program { struct huiyuan { public string name; public st ...

  7. JavaWeb学习记录(二十)——Model1模式(javaBean+jsp)实现简单计算器案例

    ¨JSP技术提供了三个关于JavaBean组件的动作元素,即JSP标签,它们分别为: ¨<jsp:useBean>标签:用于在JSP页面中查找或实例化一个JavaBean组件. ¨< ...

  8. 一个用WPF做的简单计算器源代码

    一.界面设计XAML代码 <Window x:Class="fengjisuanqi.MainWindow" xmlns="http://schemas.micro ...

  9. hdu 1237 简单计算器

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1237 简单计算器 Description 读入一个只包含 +, -, *, / 的非负整数计算表达式, ...

随机推荐

  1. zend frameword 基本语法

    #resources.frontController.moduleDirectory = APPLICATION_PATH "/modules"#resources.frontCo ...

  2. easyui formatter 返回easyui组件

    <table id="dg2" title="标题" style="width:400px;float: left;"> < ...

  3. python 基本的序列和映射规则

    >>> def checkIndex(key):...     if not isinstance(key,(int,long)):raise TypeError...     if ...

  4. ListView random IndexOutOfBoundsException on Froyo

    http://stackoverflow.com/questions/8431342/listview-random-indexoutofboundsexception-on-froyo 今天遇到个 ...

  5. Compress a folder using powershell

    There are many ways to compress a folder using powershell: Method 1: Using System.IO.Compression and ...

  6. Leetcode389

    Find the Difference Given two strings s and t which consist of only lowercase letters. 给出两个字符串,s和t,都 ...

  7. 使用nginx简单实现负载均衡

    只是简单使用nginx玩玩而已,知道能这么用,但是在实际项目中并没有实践过,在项目不大的时候用不到,但是对于理解负载均衡来说还是可以的. 利用虚拟机安装了三个centOS系统,然后顺便装了环境. 这里 ...

  8. 为什么有时候必须添加sys.setdefaultencoding('utf-8')

    今天在尝试Python的CGI模块时遇到中文字符不能正确显示的问题,很郁闷.在网上仔细找了找,终于解决了这个问题,现在将解决方法陈述如下,以防下次失误. 页面源代码如下 #-*- coding: ut ...

  9. Tomcat数据源

    Tomcat数据源原理,配置,使用 在程序中,使用数据源是可以提升操作性能的,这种性能 的提升依靠运行的操作原理. 传统的JDBC操作: 1. 加载数据库驱动,通过CLASSPATH配置 2. 通过D ...

  10. CentOS 6.5添加163源

    1.首先备份/etc/yum.repos.d/CentOS-Base.repo mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS ...