统计当前网页被访问次数的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&ouml;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);//更新文件记录
%>
但是还是不是很好,也是每次访问首页就计数一次。怎么样百分百满意呢?
 
最后一种完美解决方法,session和application加文本保存结合就完美了,不管重启服务器,还是能百分百记录所有的访问记录。
写一个severlet类似前面,就是long类型改成int类型。
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>我们的友谊海枯石烂! 你是第&nbsp;<%=count %>&nbsp;位访客</p>

 

 

以上是关于统计当前网页被访问次数的Jquery代码:的主要内容,如果未能解决你的问题,请参考以下文章

JSP简单实现统计网页访问次数

在HTML静态网页中记录图片被点击的次数统计代码?

有趣的网页小部件笔记

百度统计,统计页面加载时间,统计页面访问次数

网页被访问次数方法

华为OD机试 - 热点网络统计(JavaScript) | 机试题+算法思路+考点+代码解析 2023