当前位置: 首页 > news >正文

JSP实现网页计算器

(1)jsp实现网页计算器代码如下:只有两个jsp页面

myCal.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>My JSP 'myCal.jsp' starting page</title>

<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">


<!-- jsp页面中不可以直接使用script -->
<script language="javascript">
<!--
		//写一个函数判断是否两个数都有
		function checkNum()
		{
			//判断num1 num2是否为空
			if((form1.num1.value == "") ||  (form1.num2.value == ""))
			{
				window.alert("null,不能为空!");
				return false;
			}
			//判断是否是数字
			if(Math.round(form1.num1.value) != form1.num1.value   &&  Math.round(form1.num2.value) != form1.num2.value)
			{
				window.alert("num1和num2不是一个数");
				return false;
			}
			if(Math.round(form1.num1.value) != form1.num1.value)
			{
				window.alert("num1不是一个数");
				return false;
			}
			if(Math.round(form1.num2.value) != form1.num2.value)
			{
				window.alert("num2不是一个数");
				return false;
			}
			
		}
	
	-->
	</script>
</head>
<body>

	<form name="form1" action="calculator/myResult.jsp" method="post">
		请输入第一个数:<input type="text" name="num1"> 
		<select name="flag">
			<option value=+>+</option>
			<option value=->-</option>
			<option value=*>*</option>
			<option value=/>/</option>
		</select> 
		请输入第二个数:<input type="text" name="num2"> 
		<input type="submit" value="计算" οnclick="return checkNum();">
	</form>

</body>
</html>

myResult.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>My JSP 'myResult.jsp' starting page</title>
    
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->

  </head>
  
  <body>
  <%
  	//第1步接收到 第1个数
  	String s_num1 = request.getParameter("num1");
  	//第2步接收到 第2个数
  	String s_num2 = request.getParameter("num2");
  	//第3步接收到 运算符
  	String flag = request.getParameter("flag");
  	//第4步 计算
  	
  	int num1 = Integer.parseInt(s_num1);
  	int num2 = Integer.parseInt(s_num2);
  	int result = 0;
  	if(flag.equals("+"))
  	{
  		result = num1+num2;
  	}
  	else if(flag.equals("-"))
  	{
  		result = num1-num2;
  	}
  	else if(flag.equals("*"))
  	{
  		result = num1*num2;
  	}
  	else if(flag.equals("/"))
  	{
  		result = num1/num2;
  	}
  	//第5步
  	out.println("结果是:"+result);
   %>  
    
  </body>
</html>

(2)虽然过程很简单但是有几个值得学习的地方:


如何判断输入的数据是不是数字:使用Math.round(form1.num1.value) != form1.num1.value   来判断;

如何获取操作值:设置name属性  flag实现;


相关文章:

  • MySQL汇总数据
  • 如何配置Tomcat的热启动
  • vncserver
  • 项目路径配置[pageContext.request.contextPath]和c标签
  • JSP隐含对象response实现文件下载的两种方式
  • JSP动态生成验证码
  • 报表性能优化方案之多种报表服务器内存修改方法
  • JSP用过滤器解决request中文乱码问题
  • Advanced R之编程风格
  • SpringMVC实现一个controller写多个方法
  • 枚举类型的抽象方法定义实现
  • 大数据笔记07:大数据之Hadoop的HDFS(特点)
  • 【数据库学习笔记】(1)JDBC驱动程序的分类
  • 【数据库学习笔记】(2)JDBC加载并注册数据库驱动并连接数据库
  • 【数据库学习笔记】(3)SQL数据类型与Java数据类型的对应关系
  • 【跃迁之路】【519天】程序员高效学习方法论探索系列(实验阶段276-2018.07.09)...
  • canvas实际项目操作,包含:线条,圆形,扇形,图片绘制,图片圆角遮罩,矩形,弧形文字...
  • Django 博客开发教程 8 - 博客文章详情页
  • es6--symbol
  • JavaScript的使用你知道几种?(上)
  • javascript面向对象之创建对象
  • Java反射-动态类加载和重新加载
  • MobX
  • Netty 框架总结「ChannelHandler 及 EventLoop」
  • python_bomb----数据类型总结
  • rabbitmq延迟消息示例
  • vue-cli在webpack的配置文件探究
  • 阿里云应用高可用服务公测发布
  • 动态规划入门(以爬楼梯为例)
  • 精彩代码 vue.js
  • 如何解决微信端直接跳WAP端
  • 世界编程语言排行榜2008年06月(ActionScript 挺进20强)
  • 学习JavaScript数据结构与算法 — 树
  • ​​​​​​​​​​​​​​汽车网络信息安全分析方法论
  • $$$$GB2312-80区位编码表$$$$
  • (51单片机)第五章-A/D和D/A工作原理-A/D
  • (day 2)JavaScript学习笔记(基础之变量、常量和注释)
  • (LeetCode C++)盛最多水的容器
  • (zhuan) 一些RL的文献(及笔记)
  • (更新)A股上市公司华证ESG评级得分稳健性校验ESG得分年均值中位数(2009-2023年.12)
  • (解决办法)ASP.NET导出Excel,打开时提示“您尝试打开文件'XXX.xls'的格式与文件扩展名指定文件不一致
  • (入门自用)--C++--抽象类--多态原理--虚表--1020
  • (删)Java线程同步实现一:synchronzied和wait()/notify()
  • (顺序)容器的好伴侣 --- 容器适配器
  • (四)搭建容器云管理平台笔记—安装ETCD(不使用证书)
  • (原)Matlab的svmtrain和svmclassify
  • (转)shell调试方法
  • .Mobi域名介绍
  • .NET 2.0中新增的一些TryGet,TryParse等方法
  • .Net 代码性能 - (1)
  • .NET/C# 判断某个类是否是泛型类型或泛型接口的子类型
  • .NET上SQLite的连接
  • .NET应用架构设计:原则、模式与实践 目录预览
  • @EnableConfigurationProperties注解使用
  • @transactional 方法执行完再commit_当@Transactional遇到@CacheEvict,你的代码是不是有bug!...