hta編寫(xiě)的消費(fèi)記錄程序
發(fā)布日期:2021-12-20 15:31    |    文章來(lái)源:源碼之家
										
									
									
將代碼復(fù)制粘貼到一文本文檔中,然后保存,并將該文件后綴名改為:hta,雙擊即可運(yùn)行。
<!--////////程序說(shuō)明/////////====
程序名稱(chēng):消費(fèi)記錄Ver1.1(20070808-20070811).hta
使用說(shuō)明:將代碼復(fù)制粘貼到一文本文檔中,然后保存,并將該文件后綴名改為:hta,雙擊即可運(yùn)行。
作者說(shuō)明:youxi01,,,版權(quán)沒(méi)有,歡迎盜版!!///////////-->
<!--///////設(shè)置題頭,編碼方式//////-->
<TITLE>消費(fèi)記錄程序</TITLE>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"/>
<!--///////hta標(biāo)志//////-->
<HTA:APPLICATION
SCROLL="no"
CAPTION="yes"
SYSMENU="yes"/>
<!--///////控制程序部分//////-->
<script language="vbscript">
totalMoney=0 '總消費(fèi)額
index=-1 '初始化checkbox控件ID序號(hào);
flag=0 '定義文件是否改動(dòng)的標(biāo)志
set fso=createobject("scripting.filesystemobject")
'///////////////////文件載入時(shí),讀取配置文件,定義自身大小、位置////////
Sub Window_onLoad
if not (fso.fileexists("consume.ini")) then '不存在配置文件則創(chuàng)建;
fso.createtextfile("consume.ini").close
end if
window.resizeTo 638,495 '設(shè)置自身大小、位置;
window.moveTo 200,100
addRow 0,"hoho","2007-1-1","星期二" '先添加一個(gè)行。自己都搞不明白,反正用來(lái)處理bug;
document.all.namedItem("mytable").rows(1).style.display="none" '設(shè)置這行不可見(jiàn);
addRow 0,"hoho","2007-1-1","星期二" '再添加一個(gè)行。自己都搞不明白,反正用來(lái)處理bug;
document.all.namedItem("mytable").rows(2).style.display="none" '設(shè)置這行不可見(jiàn);
readFile("consume.ini")
End Sub
'//////////////////讀取文件//////////////////
Function readFile(filename)
set file=fso.opentextfile(filename,1,1)
do while file.atendofline<>true '讀文件一直到文件尾部
str=split(file.readline,"#") '按#標(biāo)志分割沒(méi)行(總共有四個(gè)這種標(biāo)志)
addRow str(1),str(2),str(3),str(4) '添加五個(gè)單元格,內(nèi)容分別為....
loop
End Function
'////////////////添加表行,單元格///////////
Function addRow(cnum,ctype,cdate,cday)
index=index+1 '序號(hào)自加1
set objTable=document.all.namedItem("mytable") '根據(jù)ID獲取對(duì)象表格
set newrow = objTable.insertRow() '插入一行
newrow.className="row_add" '設(shè)置該行的樣式;
newrow.onmouseover=getRef("change_bgcolor")
newrow.onmouseout=getRef("back_bgcolor")
newrow.onclick=getRef("chooseOBJ")
var="#"&cnum&"#"&ctype&"#"&cdate&"#"&cday
str=split(var,"#")
str(0)="<input type=checkbox id='delcheck'&index>"
for i=0 to 4
set newcell=newrow.insertCell() '插入單元格,并設(shè)置單元格的值;
newcell.innerhtml=str(i)
next
totalMoney=totalMoney+clng(cnum) '設(shè)置總消費(fèi)額的值,并定義顯示;
consume.innerHTML="消費(fèi)總額:"&totalMoney&"元"
End Function
'///////////////改變對(duì)象背景//////////////
Function change_bgcolor()
me.className="new_row_add"
End Function
'/////////////返回原來(lái)背景色//////////////
Function back_bgcolor()
me.className="row_add"
End Function
'////////////選定該行/////////
Function chooseOBJ()
if me.cells(0).children(0).checked=true then
me.cells(0).children(0).checked=false
else
me.cells(0).children(0).checked=true
end if
End Function
'/////////////////"刪除"一個(gè)單元格///////////////
Function delRow()
for i=0 to index
if delcheck(i).checked=true then
set tag=delcheck(i).parentelement.parentelement '設(shè)置該checkbox所在的行;
tag.style.display="none" '其實(shí),所謂的刪除就是把它設(shè)置為不顯示;
totalMoney=totalMoney-clng(tag.cells(1).innertext)
consume.innerHTML="消費(fèi)總額:"&totalMoney&"元"
tag.cells(1).innertext="0" '消費(fèi)額設(shè)置為0;
end if
next
flag=1 '如果執(zhí)行了刪除操作,則標(biāo)志文件已經(jīng)改動(dòng);
End Function
'////////////////////檢查輸入數(shù)據(jù)是否正確////////////
Function check(value)
if not (isnumeric(value)) then
msgbox "請(qǐng)?jiān)谙M(fèi)金額欄中輸入數(shù)字!",64,"特別提示"
elseif value<1 then
msgbox "你的錢(qián)難道越花越多?",64,"特別提示"
else
flag=1
addRow money.value,cstype.options(cstype.selectedIndex).innerText,date,weekdayname(weekday(date))
csmonth.selectedIndex = month(date()) '月份checkbox轉(zhuǎn)到當(dāng)前月份;
selectChange(monthname(month(date()))) '表格顯示為當(dāng)前月份的數(shù)據(jù);
end if
money.select() 'money輸入框選定;
End Function
'////////////////////////如果月份checkbox變化//////////////
Function selectChange(choose) '78行;
totalMoney=0
for i=0 to index
set tag=delcheck(i).parentelement.parentelement
mName=monthname(month(tag.cells(3).innertext)) '獲取數(shù)據(jù)的月份;
if trim(choose)="一年" and tag.cells(1).innertext<>"0" then
tag.style.display=""
totalMoney=totalMoney+clng(tag.cells(1).innertext)
elseif mName<>trim(choose) or tag.cells(1).innertext="0" then
tag.style.display="none"
else
tag.style.display=""
totalMoney=totalMoney+clng(tag.cells(1).innertext)
end if
next
consume.innerHTML="消費(fèi)總額:"&totalMoney&"元"
End Function
'////////////全選或全不選按鈕控制代碼//////
Function selectAll() '96行;
if mybutton.value="全部選擇" then
for i=0 to index
delcheck(i).checked=true
next
mybutton.value="全不選擇"
else
for i=0 to index
delcheck(i).checked=false
next
mybutton.value="全部選擇"
end if
End Function
'/////////////當(dāng)程序退出時(shí)//////////////////
Sub Window_onunLoad()
if flag=1 then '文件如果已經(jīng)標(biāo)志了改動(dòng),則提示是否保存;
msg=msgbox("提示:你的設(shè)置已經(jīng)更改,是否保存?",vbyesno+vbExclamation,"保存提醒")
if msg=6 then '如果選擇了“是”;
selectChange("一年") '當(dāng)前表格顯示的數(shù)據(jù)為全年的數(shù)據(jù);
for i=0 to index
set tag=delcheck(i).parentelement.parentelement
if tag.cells(1).innertext<>"0" then
txt=txt&"#"&tag.cells(1).innertext&"#"&tag.cells(2).innertext&"#"
txt=txt&tag.cells(3).innertext&"#"&tag.cells(4).innertext & vbcrlf
end if
next
set file=fso.opentextfile("consume.ini",2,1) '覆蓋寫(xiě)入文件;
file.write(txt).close
end if
end if
End Sub
</script>
<!--///////以上為控制代碼,以下為樣式代碼/////////////-->
<style>
#all{border:1px solid #000069;width:600px;text-align:center;padding:2px;}
#header{width:598px;text-align:center;font-family: "隸書(shū)";font-size: 24px;
font-weight: bold;background: #EEE;margin:1px;}
#header1{text-align:center;font-size: 16px;width:595px;padding:2px 2px;}
#month{float:left;width:20px;margin-left:90px;}
#consume{float:left;width:200px;color:red}
#main{width:600px;height:300px;background: #EEE;border:1px solid #000069;overflow:auto;}
#contain{width:600px;height:30px;border:1px solid #000069;}
.line{border:1px solid #000060; height: 1;width:602px;}
.line2{border:1px solid white; height: 1;width:600px;}
.c_button{text-align:center;float:left;width:100px;border:1px solid #ccc;
background-color:#F3F3F3;font-size:12px;color:#333333;
padding:5px 2px;margin:2px;line-height:20px;}
.c_other{text-align:center;float:left;width:136px;
border:1px solid #ccc;background-color:#F3F3F3;font-size:12px;color:#333333;
padding:5px 2px;margin:2px;line-height:20px;height:23px; }
.button {padding:1px;text-align:center;border:0;background-color:#eee;height:23px;cursor:pointer}
.th{text-align=center;background-color:#006699;font-size:14px;
font-family: "隸書(shū)";color:#F2F3F7;padding:2px;line-height:22px;}
.row_add{text-align:center;background-color:#ccd2de;height:4px;font-size:12px;line-height:15px;
padding:2px;}
.new_row_add{text-align:center;color:red;background-color:#ccd2ad;height:4px; font-size:12px;
line-height:15px;padding:2px;cursor:hand;}
</style>
<!--///////以下為要顯示對(duì)象/////////////-->
<hr class="line">
<div ID="all">
<div id="header">2007年消費(fèi)一覽表</div>
<div id="header1">
<div id="month"><select id="csmonth" onchange=selectChange(csmonth.options(csmonth.selectedIndex).innerText)><option>一年</option><option>一月</option><option>二月</option><option>三月</option><option>四月</option><option>五月</option><option>六月</option><option>七月</option><option>八月</option><option>九月</option><option>十月</option><option>十一月</option><option>十二月</option></select></div>
<div id="consume">消費(fèi)總額:</div></div>
<div id="main">
<table border=0 width=100% ID="mytable">
<tr class="th"><th>選定</th><th>消費(fèi)金額</th><th>消費(fèi)類(lèi)型</th><th>消費(fèi)日期</th><th>消費(fèi)星期</th>
</table></div>
<hr class="line2" color=white>
<div id="contain">
<div class="c_button"><input type=submit value="全部選擇" class="button" ID="mybutton" onclick=selectAll></div>
<div class="c_other">消費(fèi)金額:<input type=text name="money" size=5 onmouseover='money.select()'></div>
<div class="c_other">消費(fèi)類(lèi)型:<select ID="cstype"><option>飲食</option><option>娛樂(lè)</option><option>其它</option></select></div>
<div class="c_button"><input type=submit value="添加記錄" class="button" onclick=check(money.value)></div><div class="c_button"><input type=submit value="刪除記錄" class="button" onclick=delRow()></div>
</div></div>
									
									
									復(fù)制代碼 代碼如下:
<!--////////程序說(shuō)明/////////====
程序名稱(chēng):消費(fèi)記錄Ver1.1(20070808-20070811).hta
使用說(shuō)明:將代碼復(fù)制粘貼到一文本文檔中,然后保存,并將該文件后綴名改為:hta,雙擊即可運(yùn)行。
作者說(shuō)明:youxi01,,,版權(quán)沒(méi)有,歡迎盜版!!///////////-->
<!--///////設(shè)置題頭,編碼方式//////-->
<TITLE>消費(fèi)記錄程序</TITLE>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"/>
<!--///////hta標(biāo)志//////-->
<HTA:APPLICATION
SCROLL="no"
CAPTION="yes"
SYSMENU="yes"/>
<!--///////控制程序部分//////-->
<script language="vbscript">
totalMoney=0 '總消費(fèi)額
index=-1 '初始化checkbox控件ID序號(hào);
flag=0 '定義文件是否改動(dòng)的標(biāo)志
set fso=createobject("scripting.filesystemobject")
'///////////////////文件載入時(shí),讀取配置文件,定義自身大小、位置////////
Sub Window_onLoad
if not (fso.fileexists("consume.ini")) then '不存在配置文件則創(chuàng)建;
fso.createtextfile("consume.ini").close
end if
window.resizeTo 638,495 '設(shè)置自身大小、位置;
window.moveTo 200,100
addRow 0,"hoho","2007-1-1","星期二" '先添加一個(gè)行。自己都搞不明白,反正用來(lái)處理bug;
document.all.namedItem("mytable").rows(1).style.display="none" '設(shè)置這行不可見(jiàn);
addRow 0,"hoho","2007-1-1","星期二" '再添加一個(gè)行。自己都搞不明白,反正用來(lái)處理bug;
document.all.namedItem("mytable").rows(2).style.display="none" '設(shè)置這行不可見(jiàn);
readFile("consume.ini")
End Sub
'//////////////////讀取文件//////////////////
Function readFile(filename)
set file=fso.opentextfile(filename,1,1)
do while file.atendofline<>true '讀文件一直到文件尾部
str=split(file.readline,"#") '按#標(biāo)志分割沒(méi)行(總共有四個(gè)這種標(biāo)志)
addRow str(1),str(2),str(3),str(4) '添加五個(gè)單元格,內(nèi)容分別為....
loop
End Function
'////////////////添加表行,單元格///////////
Function addRow(cnum,ctype,cdate,cday)
index=index+1 '序號(hào)自加1
set objTable=document.all.namedItem("mytable") '根據(jù)ID獲取對(duì)象表格
set newrow = objTable.insertRow() '插入一行
newrow.className="row_add" '設(shè)置該行的樣式;
newrow.onmouseover=getRef("change_bgcolor")
newrow.onmouseout=getRef("back_bgcolor")
newrow.onclick=getRef("chooseOBJ")
var="#"&cnum&"#"&ctype&"#"&cdate&"#"&cday
str=split(var,"#")
str(0)="<input type=checkbox id='delcheck'&index>"
for i=0 to 4
set newcell=newrow.insertCell() '插入單元格,并設(shè)置單元格的值;
newcell.innerhtml=str(i)
next
totalMoney=totalMoney+clng(cnum) '設(shè)置總消費(fèi)額的值,并定義顯示;
consume.innerHTML="消費(fèi)總額:"&totalMoney&"元"
End Function
'///////////////改變對(duì)象背景//////////////
Function change_bgcolor()
me.className="new_row_add"
End Function
'/////////////返回原來(lái)背景色//////////////
Function back_bgcolor()
me.className="row_add"
End Function
'////////////選定該行/////////
Function chooseOBJ()
if me.cells(0).children(0).checked=true then
me.cells(0).children(0).checked=false
else
me.cells(0).children(0).checked=true
end if
End Function
'/////////////////"刪除"一個(gè)單元格///////////////
Function delRow()
for i=0 to index
if delcheck(i).checked=true then
set tag=delcheck(i).parentelement.parentelement '設(shè)置該checkbox所在的行;
tag.style.display="none" '其實(shí),所謂的刪除就是把它設(shè)置為不顯示;
totalMoney=totalMoney-clng(tag.cells(1).innertext)
consume.innerHTML="消費(fèi)總額:"&totalMoney&"元"
tag.cells(1).innertext="0" '消費(fèi)額設(shè)置為0;
end if
next
flag=1 '如果執(zhí)行了刪除操作,則標(biāo)志文件已經(jīng)改動(dòng);
End Function
'////////////////////檢查輸入數(shù)據(jù)是否正確////////////
Function check(value)
if not (isnumeric(value)) then
msgbox "請(qǐng)?jiān)谙M(fèi)金額欄中輸入數(shù)字!",64,"特別提示"
elseif value<1 then
msgbox "你的錢(qián)難道越花越多?",64,"特別提示"
else
flag=1
addRow money.value,cstype.options(cstype.selectedIndex).innerText,date,weekdayname(weekday(date))
csmonth.selectedIndex = month(date()) '月份checkbox轉(zhuǎn)到當(dāng)前月份;
selectChange(monthname(month(date()))) '表格顯示為當(dāng)前月份的數(shù)據(jù);
end if
money.select() 'money輸入框選定;
End Function
'////////////////////////如果月份checkbox變化//////////////
Function selectChange(choose) '78行;
totalMoney=0
for i=0 to index
set tag=delcheck(i).parentelement.parentelement
mName=monthname(month(tag.cells(3).innertext)) '獲取數(shù)據(jù)的月份;
if trim(choose)="一年" and tag.cells(1).innertext<>"0" then
tag.style.display=""
totalMoney=totalMoney+clng(tag.cells(1).innertext)
elseif mName<>trim(choose) or tag.cells(1).innertext="0" then
tag.style.display="none"
else
tag.style.display=""
totalMoney=totalMoney+clng(tag.cells(1).innertext)
end if
next
consume.innerHTML="消費(fèi)總額:"&totalMoney&"元"
End Function
'////////////全選或全不選按鈕控制代碼//////
Function selectAll() '96行;
if mybutton.value="全部選擇" then
for i=0 to index
delcheck(i).checked=true
next
mybutton.value="全不選擇"
else
for i=0 to index
delcheck(i).checked=false
next
mybutton.value="全部選擇"
end if
End Function
'/////////////當(dāng)程序退出時(shí)//////////////////
Sub Window_onunLoad()
if flag=1 then '文件如果已經(jīng)標(biāo)志了改動(dòng),則提示是否保存;
msg=msgbox("提示:你的設(shè)置已經(jīng)更改,是否保存?",vbyesno+vbExclamation,"保存提醒")
if msg=6 then '如果選擇了“是”;
selectChange("一年") '當(dāng)前表格顯示的數(shù)據(jù)為全年的數(shù)據(jù);
for i=0 to index
set tag=delcheck(i).parentelement.parentelement
if tag.cells(1).innertext<>"0" then
txt=txt&"#"&tag.cells(1).innertext&"#"&tag.cells(2).innertext&"#"
txt=txt&tag.cells(3).innertext&"#"&tag.cells(4).innertext & vbcrlf
end if
next
set file=fso.opentextfile("consume.ini",2,1) '覆蓋寫(xiě)入文件;
file.write(txt).close
end if
end if
End Sub
</script>
<!--///////以上為控制代碼,以下為樣式代碼/////////////-->
<style>
#all{border:1px solid #000069;width:600px;text-align:center;padding:2px;}
#header{width:598px;text-align:center;font-family: "隸書(shū)";font-size: 24px;
font-weight: bold;background: #EEE;margin:1px;}
#header1{text-align:center;font-size: 16px;width:595px;padding:2px 2px;}
#month{float:left;width:20px;margin-left:90px;}
#consume{float:left;width:200px;color:red}
#main{width:600px;height:300px;background: #EEE;border:1px solid #000069;overflow:auto;}
#contain{width:600px;height:30px;border:1px solid #000069;}
.line{border:1px solid #000060; height: 1;width:602px;}
.line2{border:1px solid white; height: 1;width:600px;}
.c_button{text-align:center;float:left;width:100px;border:1px solid #ccc;
background-color:#F3F3F3;font-size:12px;color:#333333;
padding:5px 2px;margin:2px;line-height:20px;}
.c_other{text-align:center;float:left;width:136px;
border:1px solid #ccc;background-color:#F3F3F3;font-size:12px;color:#333333;
padding:5px 2px;margin:2px;line-height:20px;height:23px; }
.button {padding:1px;text-align:center;border:0;background-color:#eee;height:23px;cursor:pointer}
.th{text-align=center;background-color:#006699;font-size:14px;
font-family: "隸書(shū)";color:#F2F3F7;padding:2px;line-height:22px;}
.row_add{text-align:center;background-color:#ccd2de;height:4px;font-size:12px;line-height:15px;
padding:2px;}
.new_row_add{text-align:center;color:red;background-color:#ccd2ad;height:4px; font-size:12px;
line-height:15px;padding:2px;cursor:hand;}
</style>
<!--///////以下為要顯示對(duì)象/////////////-->
<hr class="line">
<div ID="all">
<div id="header">2007年消費(fèi)一覽表</div>
<div id="header1">
<div id="month"><select id="csmonth" onchange=selectChange(csmonth.options(csmonth.selectedIndex).innerText)><option>一年</option><option>一月</option><option>二月</option><option>三月</option><option>四月</option><option>五月</option><option>六月</option><option>七月</option><option>八月</option><option>九月</option><option>十月</option><option>十一月</option><option>十二月</option></select></div>
<div id="consume">消費(fèi)總額:</div></div>
<div id="main">
<table border=0 width=100% ID="mytable">
<tr class="th"><th>選定</th><th>消費(fèi)金額</th><th>消費(fèi)類(lèi)型</th><th>消費(fèi)日期</th><th>消費(fèi)星期</th>
</table></div>
<hr class="line2" color=white>
<div id="contain">
<div class="c_button"><input type=submit value="全部選擇" class="button" ID="mybutton" onclick=selectAll></div>
<div class="c_other">消費(fèi)金額:<input type=text name="money" size=5 onmouseover='money.select()'></div>
<div class="c_other">消費(fèi)類(lèi)型:<select ID="cstype"><option>飲食</option><option>娛樂(lè)</option><option>其它</option></select></div>
<div class="c_button"><input type=submit value="添加記錄" class="button" onclick=check(money.value)></div><div class="c_button"><input type=submit value="刪除記錄" class="button" onclick=delRow()></div>
</div></div>
版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。
									相關(guān)文章
														
														
														
														
														
														
														
														
														
														
									
									
									
								 關(guān)注官方微信
                    關(guān)注官方微信