編程(Programming)是編定程序的中文簡稱,就是讓計算機代碼解決某個問題,對某個計算體系規定一定的運算方式,使計算體系按照該計算方式運行,并最終得到相應結果的過程。為了使計算機能夠理解(understand)人的意圖,人類就必須將需解決的問題的思路、方法和手段通過計算機能夠理解的形式告訴計算機,使得計算機能夠根據人的指令一步一步去工作,完成某種特定的任務。這種人和計算體系之間交流的過程就是編程。 【實例名稱】 通過JS對密碼強度進行檢查 【實例描述】 密碼強度檢查一般用在網站用戶注冊時,用來檢查用戶輸入的密碼是否安全,此功能也是Ajax Web 2.0技術的特色。本例學習使用JavaScript實現密碼強度檢查。 【實例代碼】 <html>
<head>
<title>密碼強度提示-本站(www.xue51.com)</title>
<style type="text/css">
#chkResult{margin-left:53px;height:15px;}
</style>
</head>
<body>
<form name="form1">
<label for="pwd">用戶密碼</label>
<input type="password" name="pwd" onblur="chkpwd(this)" />
<div id="chkResult"></div>
<label for="pwd2">重復密碼</label>
<input type="password" name="pwd2" />
</form>
<script type="text/javascript">
//檢測密碼的方法
function chkpwd(obj)
{
var t=obj.value;
var id=getResult(t);
//定義對應的消息提示
var msg=new Array(4);
msg[0]="密碼太短。";
msg[1]="密碼強度比較差。";
msg[2]="密碼強度一般。";
msg[3]="密碼強度高。";
var sty=new Array(4);
sty[0]=-45;
sty[1]=-30;
sty[2]=-15;
sty[3]=0;
//消息提示對應的顏色
var col=new Array(4);
col[0]="gray";
col[1]="red";
col[2]="#ff6600";
col[3]="Green"; //設置顯示效果
var sWidth=300;
var sHeight=15;
var Bobj=document.getElementById("chkResult");
Bobj.style.fontSize="12px";
Bobj.style.color=col[id];
Bobj.style.width=sWidth + "px";
Bobj.style.height=sHeight + "px";
Bobj.style.lineHeight=sHeight + "px";
Bobj.style.textIndent="20px";
Bobj.innerHTML="密碼檢測提示:" + msg[id];
} //定義檢測函數,返回0/1/2/3分別代表無效/差/一般/強
function getResult(s){
if(s.length < 4){
return 0;
}
var ls = 0;
if (s.match(/[a-z]/ig)){
ls++;
}
if (s.match(/[0-9]/ig)){
ls++;
}
if (s.match(/(.[^a-z0-9])/ig)){
ls++;
}
if (s.length < 6 && ls > 0){
ls--;
}
return ls
}
</script>
</body>
</html>
【運行效果】  【難點剖析】 本例的難點在于判斷用戶輸入的密碼是字母還是數字,這里使用了正則表達式。“s.match(/[a-z]/ig)”用來檢測字母,“s.match(/[o一9]/ig)”用來檢測數字,“s.match(/(.[^a-z0-9】)/ig)”則檢查密碼是否既包含字母又包含數字。 【源碼下載】 為了JS代碼的準確性,請點擊:通過JS對密碼強度進行檢查 進行本實例源碼下載
使用編程語言寫的程序,由于每條指令都對應計算機一個特定的基本動作,所以程序占用內存少、執行效率高。 |