<head>
<title></title>
<script type="text/javascript" language="javascript">
function getTime() {//js函数,定期执行的函数主体
var dateTime = new Date()//新建系统时间的对象
var hour = formatTime(dateTime.getHours())//获取小时并格式化,格式化函数formatTime(),下同
var minute = formatTime(dateTime.getMinutes())//获取分
var second = formatTime(dateTime.getSeconds())//获取秒
// var millisecond = dateTime.getMilliseconds()//获取毫秒
var code = "当前时间是:" + hour + ":" + minute + ":" + second//+ " " + millisecond//第一个div的内容(数字时钟)
var codeChinese = "当前时间是:" + formatChinese(hour) + "时" + formatChinese(minute) + "分" + formatChinese(second) + "秒"//第二个div的内容(中文时钟)
document.getElementById("divTime").innerHTML = code//第一个div内容填充
document.getElementById("divTimeChinese").innerHTML = codeChinese//第二个div内容填充
document.getElementById("monDigitalClock").innerHTML = makeMonCode(hour.toString() + ":" + minute.toString() + ":" + second.toString()) + blockEmpty()//+ makeMonCode(millisecond.toString())
updateLatestTime()//更新剩余时间
}
function formatTime(num) {//格式化数字,小于10时在数字前添加0
if (num < 10) {
return "0" + num
}
else {
return num
}
}
function formatChinese(num) {//中文格式处理
var str = String(num)
if (str.length == 1) {//一位数的情况,直接返回中文
return formatSingleNumber(str)
}
else {//两位数的情况
var mid = "十"
var top = str.substr(0, 1)//第一位
var btn = str.substr(1, 2)//第二位
return (formatSingleNumber(top) + mid + formatSingleNumber(btn)).replace("零十", "零").replace("十零", "十").replace("零零", "零").replace("一十", "十")//使用formatSingleNumber函数转换成中文并将不符合中文数字表示方法的替换一下
}
}
function formatSingleNumber(num) {//单个数字转化成中文
return num.replace("1", "一").replace("2", "二").replace("3", "三").replace("4", "四").replace("5", "五").replace("6", "六").replace("7", "七").replace("8", "八").replace("9", "九").replace("0", "零")
}
setInterval("getTime()", 1000)//定时刷新,每毫秒刷新一次
//模拟时钟代码
function buidlPointArea(num) {//将数字对应的点阵拼接成图案
var code = "<div class='singleNumber'>"
for (var i = 1 i < 6 i++) {
for (var j = 1 j < 5 j++) {
code += createSinglePoint(i + "_" + j, num)
}
}
code += "</div>"
return code
}
function createSinglePoint(id, num) {//数字对应的黑点
var array0 = new Array("1_1", "1_2", "1_3", "2_1", "2_3", "3_1", "3_3", "4_1", "4_3", "5_1", "5_2", "5_3")//数字0的点阵,下同
var array1 = new Array("1_3", "2_3", "3_3", "4_3", "5_3")
var array2 = new Array("1_1", "1_2", "1_3", "2_3", "3_1", "3_2", "3_3", "4_1", "5_1", "5_2", "5_3")
var array3 = new Array("1_1", "1_2", "1_3", "2_3", "3_1", "3_2", "3_3", "4_3", "5_1", "5_2", "5_3")
var array4 = new Array("1_1", "1_3", "2_1", "2_3", "3_1", "3_2", "3_3", "4_3", "5_3")
var array5 = new Array("1_1", "1_2", "1_3", "2_1", "3_1", "3_2", "3_3", "4_3", "5_1", "5_2", "5_3")
var array6 = new Array("1_1", "1_2", "1_3", "2_1", "3_1", "3_2", "3_3", "4_1", "4_3", "5_1", "5_2", "5_3")
var array7 = new Array("1_1", "1_2", "1_3", "2_3", "3_3", "4_3", "5_3")
var array8 = new Array("1_1", "1_2", "1_3", "2_1", "2_3", "3_1", "3_2", "3_3", "4_1", "4_3", "5_1", "5_2", "5_3")
var array9 = new Array("1_1", "1_2", "1_3", "2_1", "2_3", "3_1", "3_2", "3_3", "4_3", "5_1", "5_2", "5_3")
var numArr = new Array()
numArr[0] = array0
numArr[1] = array1
numArr[2] = array2
numArr[3] = array3
numArr[4] = array4
numArr[5] = array5
numArr[6] = array6
numArr[7] = array7
numArr[8] = array8
numArr[9] = array9
var cls = "whitePoint"
for (var i = 0 i < numArr[num].length i++) {
if (id == numArr[num][i]) {
cls = "blackPoint"
}
}
return "<div id='" + id + "' class='" + cls + "'></div>"
}
function blockEmpty() {//空格代码
return "<div class='singleNumber'></div>"
}
function blockM() {//冒号的代码
var code = ""
code += "<div class='singleNumber'><div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='blackPoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='blackPoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div>"
code += "<div class='whitePoint'></div></div>"
return code
}
function makeMonCode(totalCode) {//生成模拟的数字时钟代码
var finalCode = ""
for (var i = 0 i < totalCode.length i++) {//每个字符分别转换
if (isNaN(totalCode[i])) {//非数字字符,例子中只有冒号
if (totalCode[i] == ":") {
finalCode += blockM()//冒号的代码,用blockM()函数生成
}
}
else {
finalCode += buidlPointArea(totalCode[i])//数字的代码,用buildPointArea()函数生成
}
}
return finalCode
}
function updateLatestTime() {//更新剩余时间
var setHour = document.getElementById("sltHour").value//获取选择的小时值
var setMin = document.getElementById("sltMin").value//获取选择的分值
var setSecond = document.getElementById("sltSecond").value//获取选择的秒值
var time = new Date()//获取系统时间
var nowHour = time.getHours()//当前时间小时值
var nowMin = time.getMinutes()//当前时间分值
var nowSecond = time.getSeconds()//当前时间秒值
var viewHour = setHour - nowHour//剩余小时
var viewMin = setMin - nowMin//剩余分钟
var viewSecond = setSecond - nowSecond//剩余秒
if (viewSecond < 0) {//剩余秒小于0时,借位
viewSecond += 60
viewMin -= 1
}
if (viewMin < 0) {//剩余分小于0时,借位
viewMin += 60
viewHour -= 1
}
if (viewHour < 0) {//剩余小时小于0时,借位
viewHour += 24
}
document.getElementById("divLatestTime").innerHTML = "剩余时间为:" + viewHour + "时" + viewMin + "分" + viewSecond + "秒"//填充
if (viewHour == 0 && viewMin == 0 && viewSecond == 0) {//到点提示
alert("到点了!")
}
}
function createSelect() {//生成选择框代码
var code = ""
code += "请选择闹钟时间:<select id='sltHour' onchange='updateLatestTime()'>"
for (var i = 1 i < 25 i++) {
code += "<option value='" + i + "'>" + i + "</option>"
}
code += "</select>时"
code += "<select id='sltMin' onchange='updateLatestTime()'>"
for (var k = 1 k < 61 k++) {
code += "<option value='" + k + "'>" + k + "</option>"
}
code += "</select>分"
code += "<select id='sltSecond' onchange='updateLatestTime()'>"
for (var j = 1 j < 61 j++) {
code += "<option value='" + j + "'>" + j + "</option>"
}
code += "</select>秒"
document.getElementById("divAlert").innerHTML = code
}
</script>
<style type="text/css">
body {
background-color: #FFFFFF
}
.clsTime {
width: 600px
height: 50px
font-size: 30px
margin-left: auto
margin-right: auto
margin-top: 100px
}
.whitePoint {
width: 10px
height: 10px
background-color: #FFFFFF
margin: 0px
padding: 0px
float: left
}
.blackPoint {
width: 10px
height: 10px
background-color: #000000
margin: 0px
padding: 0px
float: left
}
.clsMonDigitalClock {
margin-left: auto
margin-right: auto
width: 480px
height: 50px
background-color: #FFFFFF
}
.singleNumber {
width: 40px
height: 50px
float: left
font-size: 8px
}
.clsAlert {
width: 400px
margin-top: 50px
margin-left: auto
margin-right: auto
}
.clsLatestTime {
width: 400px
margin-top: 50px
margin-left: auto
margin-right: auto
}
</style>
</head>
<body onload="createSelect()">
<div id="divTime" class="clsTime">loading....</div>
<div id="divTimeChinese" class="clsTime">loading....</div>
<div id="monDigitalClock" class="clsMonDigitalClock"></div>
<div id="divAlert" class="clsAlert"></div>
<div id="divLatestTime" class="clsLatestTime"></div>
</body>
</html>
之前做着玩的,有你说到的功能,有兴趣看看。代码存为html即可。
JS计算文本域剩余字数
function
displaySpareNumber(_this,size)
{
var
spareNumber=document.getElementById("spareNumber")
//汉字长度
var
len=_this.value.replace(/[^\x00-\xff]/gi,'xx').length
var
snum=parseInt(size)-len
spareNumber.value=snum
if(snum(size/2))
{
_this.value=_this.value.substring(0,size/2)
}
else
{
_this.value=_this.value.substring(0,size-(len-_this.value.length))
}
}
else
{
_this.value=_this.value.substring(0,size)
}
spareNumber.value=0
return
}
}
剩
注:
displaySpareNumber(this,10)
与
<input
id="spareNumber"
name="spareNumber"
value="10"
size="1"/>
中的10是你定义的内容长度.
[Ctrl+A
全选
注:如需引入外部Js需刷新才能执行]
1.等价于Function.apply(),传入数组,会被迭代为函数的参数
2.在构造时(此时传值不同于apply,因为它调用的是Call而不是Construct)
3.构造字面量数组/对象