Javascript练习
1、时钟
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Javascript时钟</title>
<script type="text/javascript">
function currenttime(){
setInterval(function (){
var now = new Date();
var str ='';
str += now.getYear()+1900+'年';
str += now.getMonth()+1+'月';
str += now.getDate()+'日';
str += now.getHours()+'时';
str += now.getMinutes()+'分';
str += now.getSeconds()+'秒';
document.getElementById('left').innerHTML=str;
},1000);
}
</script>
</head>
<body>
<p>
<input type="button" value="当前时间" onclick="currenttime();"/>
</p>
<h2 id="left"></h2>
</body>
</html>
此处出现Cannot set property 'innerHTML' of null 错误,原因是设置的编号与实际的编号不符,少了单引号。
2、创建动态样式
使用DOM样式对象创建一个允许控制页面文本颜色的页面。
style.js
function changehead(){
i=document.form1.heading.selectedIndex;
headcolor = document.form1.heading.options[i].value;
document.getElementById("head1").style.color=headcolor;
}
function changebody(){
i=document.form1.body.selectedIndex;
doccolor = document.form1.body.options[i].value;
document.getElementById("p1").style.color=doccolor;
}
注意:在函数内声明创建一个外围变量名相同的变量时,必须使用var关键字
ControlStyle.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Controlling Styles with JavaScript</title>
<script type="text/javascript" src="styles.js"></script>
</head>
<body>
<h1 id="head1">Controlling Styles with JavaScript</h1>
<hr>
<p id="p1">
Select the color for paragrahs and heading using the form below.
The colors you specified will be dynamically changed in this document.
The change occurs as soon as you changge the value iof either of the drop-down lists in the form.
</p> <form name="form1">
<b>Heading color:</b>
<select name="heading" onchange="changehead();">
<option value="black">Black</option>
<option value="red">Red</option>
<option value="blue">Blue</option>
<option value="green">Green</option>
<option value="yellow">Yellow</option>
</select>
<br>
<b>Body text color:</b>
<select name="body" onchange="changebody();">
<option value="black">Black</option>
<option value="red">Red</option>
<option value="blue">Blue</option>
<option value="green">Green</option>
<option value="yellow">Yellow</option>
</select>
</form>
</body>
</html>

3、冒泡排序
var a=[5,-6,0,124,123,45,98];
var flag=false;
for(var i=0;i< a.length-1;i++){
for(var j=0;j< a.length-1-i;j++){
if(a[j]>a[j+1]){
var temp=a[j];
a[j]=a[j+1];
a[j+1]=temp;
flag=true;
}
}
if(flag)
flag=false;
else
break;
}
for(var i=0;i< a.length;i++){
document.writeln(a[i]+" ");
}
4、二分查找
<script type="text/javascript">
var arr = [1,4,53,343,1234];
function binarySearch(arr,findVal,leftIndex,rightIndex){
//前提 防止无穷递归
if(leftIndex>rightIndex){
document.writeln("找不到");
return;
}
//找到中间值
var midIndex=Math.floor((leftIndex+rightIndex)/2);
var midVal=arr[midIndex];
if(midVal>findVal){
//左边找
binarySearch(arr,findVal,leftIndex,midIndex-1);
}else if(midVal<findVal){
binarySearch(arr,findVal,midIndex+1,rightIndex);
}else{
document.writeln("找到下标为"+midVal);
return;
}
}
binarySearch(arr,4,0,arr.length-1);
</script>
5、简单的在方框内移动,要求能用按钮移动,碰到边界停下
Mario.html
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="Mario.css" type="text/css"/>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript">
function Mario(){
this.x=0;
this.y=0; this.move=function(direct){
switch (direct){
case "up":
var mymario = document.getElementById('mymario');
var top= mymario.style.top;
top=parseInt(top.substr(0,top.length-2));
if(top>0)
mymario.style.top=(top-10)+"px";
break;
case "left":
var mymario = document.getElementById('mymario');
var left= mymario.style.left;
left=parseInt(left.substr(0,left.length-2));
if(left>0)
mymario.style.left=(left-10)+"px";
break;
case "down":
var mymario = document.getElementById('mymario');
var top= mymario.style.top;
top=parseInt(top.substr(0,top.length-2));
if(top<360)
mymario.style.top=(top+10)+"px";
break;
case "right":
var mymario = document.getElementById('mymario');
var left= mymario.style.left;
left=parseInt(left.substr(0,left.length-2));
if(left<450)
mymario.style.left=(left+10)+"px";
break;
}
}
} var mario=new Mario();
function Mariomove(direct){
switch (direct){
case "up":
mario.move("up"); break;
case "left":
mario.move("left"); break;
case "down":
mario.move("down"); break;
case "right":
mario.move("right"); break;
}
}
</script>
</head>
<body oncontextmenu="return false" onselectstart="return false">
<div class="gamediv">
<img id="mymario" style="width: 50px; left:450px; top:340px; position:absolute;" src="my.jpg" alt=""/>
</div>
<table class="control">
<tr>
<td colspan="3">游戏键盘</td>
</tr>
<tr>
<td></td>
<td><input type="button" value="up" onclick="Mariomove('up')"/></td>
<td></td>
</tr>
<tr>
<td><input type="button" value="left" onclick="Mariomove('left')"/></td>
<td></td>
<td><input type="button" value="right" onclick="Mariomove('right')"/></td>
</tr>
<tr>
<td></td>
<td><input type="button" value="down" onclick="Mariomove('down')"/></td>
<td></td>
</tr> </table>
</body>
</html>
Mario.css
.gamediv{
width: 500px;
height: 400px;
background-color: silver;
position: relative;
}
.control{
width: 200px;
height: 200px;
border: none;
}
6、正则验证email格式
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>正则验证Email格式</title>
<script type="text/javascript">
function validateInput(){
var myText = document.getElementById("myText");
var email=myText.value;
var emailReg=/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((\.[a-zA-Z0-9_-]{2,3}){1,2})$/;
if(emailReg.test(email)){
alert("success!");
}else{
alert("检验失败!");
}
}
</script>
</head>
<body style="text-align: center">
<input type="text" value="" id="myText" /> <br/><br/>
<input type="button" value="提交" id="myBtn" onclick="validateInput();"/>
</body>
</html>
Javascript练习的更多相关文章
- JavaScript之父Brendan Eich,Clojure 创建者Rich Hickey,Python创建者Van Rossum等编程大牛对程序员的职业建议
软件开发是现时很火的职业.据美国劳动局发布的一项统计数据显示,从2014年至2024年,美国就业市场对开发人员的需求量将增长17%,而这个增长率比起所有职业的平均需求量高出了7%.很多人年轻人会选择编 ...
- javascript中的Array对象 —— 数组的合并、转换、迭代、排序、堆栈
Array 是javascript中经常用到的数据类型.javascript 的数组其他语言中数组的最大的区别是其每个数组项都可以保存任何类型的数据.本文主要讨论javascript中数组的声明.转换 ...
- Javascript 的执行环境(execution context)和作用域(scope)及垃圾回收
执行环境有全局执行环境和函数执行环境之分,每次进入一个新执行环境,都会创建一个搜索变量和函数的作用域链.函数的局部环境不仅有权访问函数作用于中的变量,而且可以访问其外部环境,直到全局环境.全局执行环境 ...
- 探究javascript对象和数组的异同,及函数变量缓存技巧
javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...
- 读书笔记:JavaScript DOM 编程艺术(第二版)
读完还是能学到很多的基础知识,这里记录下,方便回顾与及时查阅. 内容也有自己的一些补充. JavaScript DOM 编程艺术(第二版) 1.JavaScript简史 JavaScript由Nets ...
- 《Web 前端面试指南》1、JavaScript 闭包深入浅出
闭包是什么? 闭包是内部函数可以访问外部函数的变量.它可以访问三个作用域:首先可以访问自己的作用域(也就是定义在大括号内的变量),它也能访问外部函数的变量,和它能访问全局变量. 内部函数不仅可以访问外 ...
- JavaScript权威指南 - 函数
函数本身就是一段JavaScript代码,定义一次但可能被调用任意次.如果函数挂载在一个对象上,作为对象的一个属性,通常这种函数被称作对象的方法.用于初始化一个新创建的对象的函数被称作构造函数. 相对 ...
- JavaScript自定义浏览器滚动条兼容IE、 火狐和chrome
今天为大家分享一下我自己制作的浏览器滚动条,我们知道用css来自定义滚动条也是挺好的方式,css虽然能够改变chrome浏览器的滚动条样式可以自定义,css也能够改变IE浏览器滚动条的颜色.但是css ...
- JavaScript进阶之路(一)初学者的开始
一:写在前面的问题和话 一个javascript初学者的进阶之路! 背景:3年后端(ASP.NET)工作经验,javascript水平一般般,前端水平一般般.学习资料:犀牛书. 如有误导,或者错误的地 ...
- 梅须逊雪三分白,雪却输梅一段香——CSS动画与JavaScript动画
CSS动画并不是绝对比JavaScript动画性能更优越,开源动画库Velocity.js等就展现了强劲的性能. 一.两者的主要区别 先开门见山的说说两者之间的区别. 1)CSS动画: 基于CSS的动 ...
随机推荐
- java编程者必收藏的十大学习网站-xiaolanglang123 -
3S博客 http://blog.3snews.net/space.php?uid=13924628&do=blog&id=70282
- 剑指offer四:链表中倒数第k个结点
输入一个链表,输出该链表中倒数第K个结点 public class ListNode { int val; ListNode next = null; ListNode(int val) { this ...
- JDBC + MySQL 示例
jdbc mysql connection 教程 翻译自:JDBC MySQL Connection Tutorial Java Database Connectivity (JDBC) 是一个基于J ...
- Sublime Text 3 支持的热门插件推荐(转载)
SublimeText是一款非常精巧的文本编辑器,适合编写代码.做笔记.写文章.它用户界面十分整洁,功能非同凡响,性能快得出奇.这些非常棒的特性 包括任意跳转(Goto Anything).多重选择( ...
- SAP ERP和ORACLE ERP的区别是哪些?
SAP有非常细致深入的标准流程,在流程方面,只要是你想到的问题,SAP都会曾经遇到过并且给出过解决方案.实施SAP比较倾向于改变企业的业务流程来匹配SAP,实现标准化管理. oracle比较灵活,侧重 ...
- python 03
数据结构 在 python 中有4种内建数据结构, 列表, 元组, 字典和集合. 列表 list 有序项目的数据结构, 类似数组, 是对象. 列表用中括号中用逗号分隔的项目定义.例如 ['apple' ...
- Android BadgeView使用
BadgeView是第三方的插件,用来显示组件上面的标记,起到提醒的作用,下载地址如下:http://files.cnblogs.com/files/hyyweb/android-viewbadger ...
- MFC编程入门之二十一(常用控件:编辑框Edit Control)
上一节讲了静态文本框,本节讲的是编辑框(Edit Control)同样是一种很常用的控件,我们可以在编辑框中输入并编辑文本.在前面加法计算器的例子中已经演示了编辑框的基本应用.下面具体讲解编辑框的使用 ...
- PHPStorm技巧篇 -- 全局搜索
自定义快捷键,找到search everywhere 我绑定的是alt+N 设置好并apply后,在项目中使用:快捷键alt+N ,输入自己需要查找的文件或类名或方法名,即可出现相应的选项. so c ...
- JAVA开发错误总结(仅记录遇到的错误---后续不断更新......)
=======华丽分割线(工具总结)===================== 1:Maven项目中junit测试找不到主类的问题 Class not found com.test.utils.tes ...