统计当前网页被访问次数的Jquery代码:
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了统计当前网页被访问次数的Jquery代码:相关的知识,希望对你有一定的参考价值。
最简单的办法:
<script type="text/javascript">
if (localStorage.pagecount) localStorage.pagecount=Number(localStorage.pagecount) +1;else localStorage.pagecount=1;document.write("访问数: " + localStorage.pagecount + " time(s).");</script>Jquery
jQuery是一套跨浏览器的JavaScript库,简化html与JavaScript之间的操作。由John Resig在2006年1月的BarCamp NYC上发布第一个版本。目前是由 Dave Methvin 领导的开发团队进行开发。全球前10000个访问最高的网站中,有59%使用了jQuery,是目前最受欢迎的JavaScript库。
简要介绍
jQuery由美国人John Resig创建,至今已吸引了来自世界各地的众多javascript高手加入其team,包括来自德国的Jörn Zaefferer,罗马尼亚的Stefan Petre等等。jQuery是继prototype之后又一个优秀的Javascrīpt框架。其宗旨是——WRITE LESS,DO MORE,写更少的代码,做更多的事情。
由于目前高校基本尚未开JavaScript的相关课程,目前jQuery的学习,使用,研究都仅限于在职Web程序员之间。
用jq的前提,首先要引用一个有jq的文件
lt;script type="text/javascript" src="http://code.jquery.com/jquery-latest.min.js"></script>
这个是jquery官方最新的地址。可用在自己网站里加个这个,就能使用jquery了。 但仍然建议下载到本地服务器上。
特点
动态特效
AJAX
通过插件来扩展
方便的工具 - 例如浏览器版本判断
渐进增强
链式调用
多浏览器支持,支持Internet Explorer6.0+、Opera9.0+、Firefox2+、Safari2.0+、Chrome1.0+(在2.0.0中取消了对Internet Explorer6,7,8的支持)
工厂函数
在编写js库代码时候,你一定经常和“$”美元符号打交道吧?无论prototype还是DWR都使用了$代替频繁的document.getElementById()操作。jQuery也这样做了,但是,它的功能远非如此,瞧瞧以下的jQuery代码,你就会发现它的美丽:
代码
var someElement = $("#myId");
看起来比其他两个框架的要多了一个#,好,看看下面的用法:
代码
$("div p"); // (1)
$("div.container"); // (2)
$("div #msg"); // (3)
$("table a",context); // (4)
在prototype里看过这样的写法吗?第一行代码得到所有div标签下的p元素。第二行代码得到class 为container的div元素,第三行代码得到标签下面id为msg的div元素(不过最好别这样写,因为jQuery需要遍历所有的div元素,对于带id的元素,直接用$("#id"))。第四行代码得到context为上下文的table里面所有的链接元素。
如果你熟悉CSS,你会觉得这些写法很眼熟!对了。正是。看出奥妙了吧。jQuery就是如此强大,你可以轻易地找到DOM中的任何元素,而这也是jQuery设计之初query的真实含义(查询)。
遍历函数
jquery提供了很多遍历的函数,如each(fn),但是使用这些函数的前提是:你使用的对象是jquery对象。使一个Dom对象成为一个jquery对象很简单,通过下面一些方式(只是一部分):
代码
var a = $("#cid");
var b = $("<p>hello</p>");
var c = document.createElement("table");
var tb = $(c);
代替标签
这个惯例,也许是除了$()之外,用得最多的地方了。下面一段代码:
$(document).ready(function()
alert"hello");
);(1)
lt;body "alert'hello');">(2)
lt;body "alert'hello');">这里的alert'hello');要等到页面全部加载完毕才执行,注意是全部加载,包括dom,图片等其它资源。
而$(document).ready(function()
alert"hello");
);(1)
当dom加载完就可以执行了。
代码1同时做到表现和逻辑分离。并且可以在不同的js文件中做相同的操作,即$(document).ready (fn)可以在一个页面中重复出现,而不会冲突。基本上Jquery的很多plugin都是利用这个特性,正因为这个特性,多个plugin共同使用起来,在初始化时不会发生冲突。
当使用jquery时,推荐使用代码1。
$(document).ready(function()fn); 可以用 $(function()fn);代替
如:
$(function()
alert"hello");
);
事件机制
我们大量使用的事件可能就是button的onclick了。以前习惯在input 元素上写 "fn()",使用jquery可以使javascrīpt代码与html代码分离,保持HTML的清洁,还可以很轻松地绑定事件,甚至你可以不知道“事件”这个名词。
代码
$(document).ready(function()
$("#clear").click(function()
alert"i am about to clear the table");
);
$("form[12]").submit(validate);
);
function validate()
//do some form validation
实现
代码
$("selector").load(url,data,function(response,status,xhr))
该方法是最简单的从服务器获取数据的方法。它几乎与 $.get(url, data, success) 等价,不同的是它不是全局函数,并且它拥有隐式的回调函数。当侦测到成功的响应时(比如,当 textStatus 为 "success" 或 "notmodified" 时),.load() 将匹配元素的 HTML 内容设置为返回的数据。这意味着该方法的大多数使用会非常简单。
渐入淡出
代码
$("#msg").show("fast");
$("#msg").hide("slow");
$("#msg").fadeIn();
$("#msg").fadeOut();
没错,上面两行代码已经分别实现了一个id为Msg的jquery对象的渐入和淡出。做一个像Gmail一样的动态加载通知条,用jquery就那么简单。两个函数接受的参数除了快慢等,还可以接收整型,作为渐入或淡出的完成时间,单位为MS。
参考技术A <script type="text/javascript">if (localStorage.pagecount)
localStorage.pagecount=Number(localStorage.pagecount) +1;
else
localStorage.pagecount=1;
document.write("访问数: " + localStorage.pagecount + " time(s).");
</script> 参考技术B <script language=JavaScript>
<!--
var caution = false
function setCookie(name, value, expires, path, domain, secure)
var curCookie = name + "=" + escape(value) +
((expires) ? "; expires=" + expires.toGMTString() : "") +
((path) ? "; path=" + path : "") +
((domain) ? "; domain=" + domain : "") +
((secure) ? "; secure" : "")
if (!caution || (name + "=" + escape(value)).length <= 4000)
document.cookie = curCookie
else
if (confirm("Cookie exceeds 4KB and will be cut!"))
document.cookie = curCookie
function getCookie(name)
var prefix = name + "="
var cookieStartIndex = document.cookie.indexOf(prefix)
if (cookieStartIndex == -1)
return null
var cookieEndIndex = document.cookie.indexOf(";", cookieStartIndex + prefix.length)
if (cookieEndIndex == -1)
cookieEndIndex = document.cookie.length
return unescape(document.cookie.substring(cookieStartIndex + prefix.length, cookieEndIndex))
function deleteCookie(name, path, domain)
if (getCookie(name))
document.cookie = name + "=" +
((path) ? "; path=" + path : "") +
((domain) ? "; domain=" + domain : "") +
"; expires=Thu, 01-Jan-70 00:00:01 GMT"
function fixDate(date)
var base = new Date(0)
var skew = base.getTime()
if (skew > 0)
date.setTime(date.getTime() - skew)
var now = new Date()
fixDate(now)
now.setTime(now.getTime() + 365 * 24 * 60 * 60 * 1000)
var visits = getCookie("counter")
if (!visits)
visits = 1
else
visits = parseInt(visits) + 1
setCookie("counter", visits, now)
document.write("您是第" + visits + "来宾!")
// -->
</script> 参考技术C 用 jquery统计比较真实可靠
load到相关统计页面即可
jsp网站访问次数统计的几种方法
我采用的是jsp网页,但是不管采用什么语言,原理是一样的。
第一种,单页面统计。就是说,只要点击这个页面就会统计一次。
<body> <%!//在这种标记中定义的变量为全局变量
int count=0;
synchronized void count(){
count++;
}
%> <% count(); out.println("这是第"+count+"个访问者!"); %> </body>
第二种,是利用jsp的内置对象application进行统计。这个程序结果运行分析,也是访问一次页面统计一次。感觉还是不够好。真正满意的是浏览器打开网页,到关闭网页算一次,这样统计比较实际。
<body> <% if (application.getAttribute("count") == null) { application.setAttribute("count", new Integer(0)); } Integer count = (Integer) application.getAttribute("count"); application .setAttribute("count", new Integer(count.intValue() + 1)); count = (Integer) application.getAttribute("count"); %> <center> 这是第<%=count.intValue()%>个访问者! </center> </body>
第三种,利用jsp的application和session进行统计。它的原理是,访问者打开浏览器到关闭浏览器算一次访问。每次打开首页,创建一个session,这个session直到浏览器关闭才失效。但总体来说,比前两种要好。但是有一个一个缺陷,那就是当jsp服务器重启时,累计的统计数就清零了。
<% int n = 0; String count = (String) application.getAttribute("counter"); if (counter != null) n = Integer.parseInt(counter); if (session.isNew())
++n; out.print("你是第" + n + "位访客"); counter = String.valueOf(n); application.setAttribute("counter", counter); %>
第四种,就是保存到txt文本中,那样重启服务器也不会丢失了。
public class counter { public static void writeFile(String filename, long count) { try { PrintWriter out = newPrintWriter(new FileWriter(filename)); out.println(count); out.close(); } catch (IOException e) { e.printStackTrace(); } } public static long readFile(String filename) { File f = new File(filename); long count = 0; if (!f.exists()) { writeFile(filename, 0); } try { BufferedReader in = newBufferedReader(newFileReader(f)); try { count = Long.parseLong(in.readLine()); } catch (NumberFormatException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } catch (FileNotFoundException e) { e.printStackTrace(); } return count; } }
下面是你要计数的jsp页面,在里面添上以下内容就ok了
<%@pageimport="com.benb.servlet.counter"%> <% counterCountFileHandler=newcounter();//创建对象 longcount=CountFileHandler.readFile(request.getRealPath("/")+"count.txt"); //读取文件获取数据赋给count count=count+1;//修改记录,数据加1 out.println(count);//显示记录数 CountFileHandler.writeFile(request.getRealPath("/")+"count.txt",count);//更新文件记录 %>
public class Counter extends HttpServlet { private static final long serialVersionUID = 1L; public Counter() { super(); } public static void writeFile(String filename, int count) { try { PrintWriter out = new PrintWriter(new FileWriter(filename)); out.println(count); out.close(); } catch (IOException e) { e.printStackTrace(); } } public static int readFile(String filename) { File f = new File(filename); int count = 0; if (!f.exists()) { writeFile(filename, 0); } try { BufferedReader in = new BufferedReader(new FileReader(f)); try { count = Integer.parseInt(in.readLine()); } catch (NumberFormatException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } catch (FileNotFoundException e) { e.printStackTrace(); } return count; } public void init() throws ServletException { // Put your code here } }
页面编码如下
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <%@ page import="com.tozhan.cn.GetDataDB" %> <%@ page import="com.tozhan.cn.news.New" %> <%@ page import="com.tozhan.cn.Counter" %> <% Counter CountFileHandler=new Counter();//创建对象 int count=0; if(application.getAttribute("count")==null){ count=CountFileHandler.readFile(request.getRealPath("/")+"count.txt"); //读取文件获取数据赋给count application.setAttribute("count",new Integer(count)); } count=(Integer)application.getAttribute("count"); if(session.isNew()) ++count; application.setAttribute("count",count); CountFileHandler.writeFile(request.getRealPath("/")+"count.txt",count);//更新文件记录 %> <p>我们的友谊海枯石烂! 你是第 <%=count %> 位访客</p>
以上是关于统计当前网页被访问次数的Jquery代码:的主要内容,如果未能解决你的问题,请参考以下文章