Rumah >hujung hadapan web >tutorial js >Cara membuat kaunter mudah menggunakan JavaScript_Basics
Pemikiran Reka Bentuk
Kunci kepada kaedah ini ialah penggunaan komprehensif teknologi kuki dan ciri imej dinamik. Menggunakan kuki, data pengguna boleh direkodkan pada pemacu keras pengguna Pada kali seterusnya anda melawat tapak ini, anda boleh membaca kuki pada pemacu keras pengguna dan terus mengetahui identiti pelawat, bilangan lawatan dan maklumat lain yang berkaitan. Kuki diakses dalam JavaScript melalui atribut document.cookie, yang merangkumi nama, tarikh tamat tempoh, nama domain yang sah, laluan URL yang sah, dsb. Nama dan nilainya yang dipisahkan oleh tanda yang sama ialah data sebenar kuki, yang dalam kes ini digunakan untuk menyimpan bilangan kali pelawat melawat halaman. Dengan memetakan imej dalam halaman Web kepada tatasusunan Imej dan mengubah suai ciri-ciri item tatasusunan dalam keadaan tertentu, paparan imej dinamik boleh dicapai. Dalam contoh ini, satu set imej terlebih dahulu dimuatkan Setiap kali halaman Web dipanggil, satu set imej baharu dijana secara rawak, dan kesan dinamik dan menarik dicapai dengan menulis ganti imej asal.
Bilangan program sumber.html
< html> < head> < meta http-equiv=″Content-Type″ content=″text/html; charset=gb2312″> < title>趣味计数器< /title> < /head> < body> < p>< script language=″JavaScript″> var expdays=60; var exp=new Date(); exp.setTime(exp.getTime() (expdays*24*60*60*1000)); function count(info){ //若是该访客的第一次访问,将计数器值赋1,否则加1累积 var wwhcount=getcookie(′wwhcount′); if (wwhcount==null){ wwhcount=1; } else{wwhcount++;} setcookie(′wwhcount′,wwhcount,exp); return countdisp(wwhcount) } function countdisp(countvar){ //实现随机显示,不足6位以0补全,可以自己调整显示位数 var countvar1=″000000″+countvar; var howFar1=countvar1.length; countvar1=countvar1.substring(howFar1, howFar1-1) var index=″ ″+Math.floor(Math.random()*10); if (index==″10″){ index=″0″}; for (var icount=0;icount< 6;icount++){ var g=countvar1.substring(icount,icount+1); document.images[icount].src=″http: //localhost/images/″+index+g+″.gif″; } } function getCookieVal(offset){ //获取该访问者的已访问次数 var endstr=document.cookie.indexOf(″;″,offset); if (endstr==-1) endstr=document.cookie.length; return unescape(document.cookie.substring(offset,endstr)); } function getcookie(name){ //截取Cookie中的name信息段 var arg=name+″=″; var alen=arg.length; var clen=document.cookie.length; var i=0; while (i< clen){ var j=i+alen; if (document.cookie.substring(i,j)==arg) return getCookieVal(j); i=document.cookie.indexOf(″ ″,i)+1; if (i==0) break;} return null; } function setcookie(name,value){ //存储该访客计数器的数值 var argv=setcookie.arguments; var argc=setcookie.arguments.length; var expires=(argc>2)?argv[2]:null;var path=(argc>3)?argv[3]:null; var domain=(argc>4)?argv[4]:null; var secure=(argc〉5)?argv[5]:false; document.cookie=name+″=″+escape(value) +((expires==null)?″ ″:(″;expires=″+expires.toGMTString())) +((path==null)?″ ″:(″;path=″+path))+((domain==null)?″ ″:(″;domain=″+domain))+((secure==true)?″;secure″:″ ″); } function deletecookie(name){ //使该信息行失效,删除该用户关于访问次数的信息 var exp=new Date(); exp.setTime(exp.getTime()-1); var cval=getcookie(name); document.cookie=name+″=″+cval+″;expires=″+exp.toGMTString(); } < /script>< /p> < ! --预载入图像数组--> 您是第 < img src=″http://localhost/images/00.gif″ height=20 width=20> < img src=″http://localhost/images/00.gif″ height=20 width=20> < img src=″http://localhost/images/00.gif″ height=20 width=20> < img src=″http://localhost/images/00.gif″ height=20 width=20> < I mg src=″http://localhost/images/00.gif″ height=20 width=20> < img src=″http://localhost/images/00.gif″ height=20 width=20>次光临! < script language=″JavaScript″> //调用count()函数,实现计数器的动态图像显示 count(); < /script> < /body> < /html>
Perkara yang perlu diberi perhatian
Memandangkan bahasa JavaScript digunakan, kaedah ini adalah bebas daripada platform aplikasi dan boleh digunakan pada Unix, Windows dan platform lain. Selain itu, kaunter ini berbeza daripada kaunter pelawat umum dan digunakan khusus untuk merekodkan bilangan kali pelawat melawat tapak web tertentu.