JavaScript 应用

目录

1、编程实现“计算任意区间内连续自然数的累加和”页面。

 代码实现

2、应用 appendChild()方法和 getElementById()方法实现年月日的联动功能。

 代码


1、编程实现“计算任意区间内连续自然数的累加和”页面。

(1)文档结构的创建

启动程序,创建 HTML 文档。在新建文档中首行插入注释语句,注明程序名

称为 prj_5_1.html。注释如下: <!-- prj_5_1.html --> 保存文件。

(2)页面内容设计

在 body 标记中插入 1 个 div、1 个 form 标记、2 个 h3 和若干表单控件。

在 body 中插入 1 个 div。

在 div 标记中插入 h3 标记,h3 标记的内容为“计算任意区间内连续自然数的累加和”。

在 div 标记中插入 form 标记。 在 form 标记中插入 h3 标记,h3 标记的内容为“定义区间”。然后插入 3 个label 双标记,其内容分别是“起始数:”、“终止数:”、“累加和:”。在每个 label 标记后分别插入 1 个单行文本输入框,它们的 id 属性值分别为 start_num、end_num、sum,name 属性值与 id 值相同,累加和文本框设置只读属性。

在 form 标记中插入 1 个普通按钮,设置 value 值为“计算”,定义 onclick 属性值为“show();”。最后插入 1 个重置按钮,设置 value 值为“清空”。

保存网页。

(3)表现设计

在 style 标记中定义图层 div 和 form 标记的样式,具体样式定义要求如下:

div 标记样式为文本居中对齐,边界上下 20px、左右自动,行高 1.5em,边框线粗细 18px、线型 groove、线颜色#66FF66,宽度 560px,高度 260px,字体标粗。 定义 form 标记样式。form 标记样式为边界上下 20px、左右自动,填充 5px。 完成样式定义后,查看页面效果。

(4)定义 JavaScript 文件 sum.js

在 head 标记中插入 script 标记,代码如下:

<script type="text/javascript" src="sum.js"></script>

编写 sum.js。 编写通过 id 号获取页面元素的通用函数$(id),如下:

function $(id){return document.getElementById(id);}

编写计算累加和的函数 sum(n1,n2),其中 n1 是起始数,n2 是终止数。

function sum(n1,n2){

 for (var i=n1,sum1=0;i<=n2 ;i++ )

 { sum1=sum1+i; }//执行累加

 return sum1;//返回计算结果

}

编写回填显示累加和的函数 show()。

该函数要求:

从起始数和终止数文本框中取出数据,两数均需要大于 0,否则要求重新输入,

起始数文本框获得焦点。 同时需满足起始数必须小于终止数,否则清空两个文本框,通过告警消息框提示错误信息,起始数文本框获得焦点。

若输入数据正确,则调用 sum(n1,n2)函数完成计算,并回填到累加和文本

框中,代码参考如下:

function show(){

 var n11=parseFloat($("start_num").value);//获取数据并转为浮点数

 var n22=parseFloat($("end_num").value);

 if (n11>0 && n22>0) //输入数据必须大于 0 {

 if ( n11>=n22)

 { alert("起始数必须小于终止数,请重输!");

 $("start_num").value=""; //清空输入域

 $("end_num").value=""; //清空输入域

 $("start_num").focus(); //输入域获得焦点 }

 else{ //回填累加和文本框

 $("sum").value=sum(n11,n22); }

 }else

 { alert("请输入数据!");

 $("start_num").focus(); //输入域获得焦点

 }}

图 5-1 设计网页效果图

 代码实现

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<style type="text/css">
			div {
				text-align: center;
				margin: 20px auto;
				line-height: 1.5em;
				border: 18px groove #66FF66;
				width: 560px;
				height: 260px;
				font-weight: bold;
			}

			form {
				margin: 20px auto;
				padding: 5px;
			}
		</style>
		<script type="text/javascript" src="sum.js"></script>
	</head>
	<body>
		<div>
			<h3>计算任意区间内连续自然数的累加和</h3>
			<form method="" action="">
				<h3>定义区间</h3>
				<label>起始数</label>
				<input type="text" id="start_num" />
				<label>终止数</label>
				<input type="text" id="end_num" />
				<label>累加和</label>
				<input type="text" id="sum" readonly="readonly" />
				<input type="button" value="计算" onclick="show()" />
				<input type="reset" value="重置" />
			</form>
		</div>
	</body>
</html>
function $(id) {
	return document.getElementById(id);
}

function sum(n1, n2) {
	for (var i = n1, sum1 = 0; i <= n2; i++) {
		sum1 = sum1 + i;
	}
	return sum1;
}

function show() {
	var n11 = parseFloat($("start_num").value);
	var n22 = parseFloat($("end_num").value);
	if (n11 > 0 && n22 > 0) {
		if (n11 >= n22) {
			alert("起始数必须小于终止数,请重输!");
			$("start_num").value = "";
			$("end_num").value = "";
			$("start_num").focus();
		} else {
			$("sum").value = sum(n11, n22);
		}
	} else {
		alert("请输入数据!");
		$("start_num").focus();
	}
}

2、应用 appendChild()方法和 getElementById()方法实现年月日的联动功能。

当改变“年”菜单和“月”菜单的值时,“日”菜单的值的范围也会相应地改变。

(1)文档结构的创建

启动程序,创建 HTML 文档。在新建文档中首行插入注释语句,注明程序名

称为 prj_5_2.html。注释如下: <!-- prj_5_2.html --> 保存文件。

(2)页面内容设计及代码编写

在页面中创建表单,在表单中定义年、月、日 3 个下拉菜单,代码如下。

<form id="form1" name="form1" method="post" action="">

 <select name="year" id="year" οnchange="getday()">

 <script type=" text/javascript ">

 var mydate=new Date();

 for(i=1990;i<=mydate.getFullYear();i++){

 document.write("<option value='"+i+"' "+(i==1990?"selected":"")+">"

+i+"年</option>"); }

 </script>

 </select>

 <select name="month" id="month" οnchange="getday()">

 <script type=" text/javascript ">

 for(i=1;i<=12;i++){

 document.write("<option value='"+i+"'"+(i==1?"selected":"")+">"

+i+"月</option>"); }

 </script> 

 </select>

 <select name="day" id="day">

 <script type=" text/javascript ">

 for(i=1;i<=31;i++){

 document.write("<option value='"+i+"'"+(i==1?"selected":"")+">"+i+"

日</option>"); }

 </script>

 </select>

</form>

创建自定义函数 append()和自定义函数 getday()。创建自定义函数 append(),先在函数中应用 createElement()函数创建下拉菜单项,并将下拉菜单项添加到相应的下拉菜单中。 创建自定义函数 getday(),在函数中根据获取的年、月的值来调用函数 append(),实现年、月、日的联动功能,代码参考如下。

<script type=" text/javascript ">

 function append(d,v){

 var option=document.createElement("option");//创建元素 option

 option.value=v;//把参数 v 作为元素的值

 option.innerText=v+"日";//把参数 v 作为元素的显示内容

 d.appendChild(option);//把元素 option 作为参数 d 的子节点 }

 function getday(){

 var y=form1.year.value;//取得年份的值

 var m=form1.month.value;//取得月份的值

 var d=document.getElementById("day");//定位到 id=day 的节点

 d.innerHTML="";//把 id=day 节点的内容清空

 if(m==4 || m==6 || m==9 || m==11){//如果月份的值是 4 或 6 或 9 或 11

 for(j=1;j<=30;j++){

 append(d,j);//把 1 到 30 循环加到天数当中 }

 }else if(m==2){//如果月份的值是 2

 if(y%4==0 && y%100!=0 ||y%400==0 ){//如果年份是闰年

 for(j=1;j<=29;j++){

 append(d,j);//把 1 到 29 循环加到天数当中

 }

 }else{

 for(j=1;j<=28;j++){

 append(d,j);//不是闰年就把 1 到 28 循环加到天数当中

 }

 }

 }else{//否则如果月份的值是 1 或 3 或 5 或 7 或 8 或 10 或 12

 for(j=1;j<=31;j++){

 append(d,j);//把 1 到 31 循环加到天数当中

 }

 }

 }

</script>

页面效果如下图所示。

 代码

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>

	</head>
	<body>
		<script language="JavaScript">
			function append(d, v) {
				var option = document.createElement("option");
				option.value = v;
				option.innerText = v + "日";
				d.appendChild(option);
			}

			function getday() {
				var y = form1.year.value;
				var m = form1.month.value;
				var d = document.getElementById("day");
				d.innerHTML = "";
				if (m == 4 || m == 6 || m == 9 || m == 11) {
					for (j = 1; j <= 30; j++) {
						append(d, j);
					}
				} else if (m == 2) {
					if (y % 4 == 0 || y % 400 == 0 && y % 100 != 0) {
						for (j = 1; j <= 29; j++) {
							append(d, j);
						}
					} else {
						for (j = 1; j <= 28; j++) {
							append(d, j);
						}
					}
				} else {
					for (j = 1; j <= 31; j++) {
						append(d, j);
					}
				}

			}
		</script>
		<form id="form1" name="form1" method="post" action="">
			<select name="year" id="year" onchange="getday()">
				<script language="JavaScript">
					var mydate = new Date();
					for (i = 1990; i <= mydate.getFullYear(); i++) {
						// document.write("<option value='''+i+'" "+(i==1990?"selected":"")+">"
						// +i+"年</option>"); 
						document.write("<option value='" + i + "' " + (i == 1999 ? "selected" : "") +
							">" + i + "年</option>");
					}
				</script>
			</select>

			<select name="month" id="month" onchange="getday()">
				<script language="JavaScript">
					for (i = 1; i <= 12; i++) {
						// document.write("<option value='''+i+'" "+(i==1?"selected":"")+">"
						// +i+"月</option>"); 
						document.write("<option value='" + i + "' " + (i == 1 ? "selected" : "") +
							">" + i + "月</option>");
					}
				</script>
			</select>

			<select name="day" id="day">
				<script language="JavaScript">
					for (i = 1; i <= 31; i++) {
						// document.write("<option value='''+i+'" "+(i==1?"selected":"")+">"
						// +i+"月</option>"); 
						document.write("<option value='" + i + "' " + (i == 1 ? "selected" : "") +
							">" + i + "日</option>");
					}
				</script>
			</select>
		</form>
	</body>
</html>

如果你喜欢这篇文章的话,请给作者点赞哟,你的支持是我不断前进的动力。

因为作者能力水平有限,欢迎各位大佬指导。

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

憨憨猿学编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值