您的位置:首页 > Web前端 > JQuery

jQuery 定时局部刷新

2012-11-26 23:22 302 查看
<html>

<head>

<script src="jquery.js" type="text/javascript"></script>

<script>

$(document).ready(function () {

setInterval("startRequest()",1000); //建议使用setTimeout
});
function startRequest(){

$("#date").text((new Date()).toString());

}

</script>

</head>

<body>

<textarea id="date" name="name" rows="10" cols="50" wrap="off">

</textarea>

</body>

</html>

php使用的一个例子
index.php:

<html>

<head>

<script src="jquery.js" type="text/javascript"></script>

<script>

$(document).ready(function(){

setInterval(function() {

$("#date").load("content.php","");

}, 1000);

});

</script>

</head>

<body>

<textarea id="date" name="name" rows="5″ cols="500″ wrap="off">

</textarea>

</body>

</html>

content.php

<?php

header("Cache-Control: no-cache, must-revalidate");

echo time();

?>

防止jQuery Load使用缓存的方法


问题:在用JQuery 加载图片并且IE下缩放时,第一次会缩放,从第二次开始,就没有效果了,经过询问,原来是IE缓存在作怪,由于IE 缓存已经存在图片,所以不会再去load,因此load一直为假,里边的函数也就无执行了。

经过网上查找,解决方法如下

一、用法

jquery的load函数是请求另一个文件并加载到当前DOM里的调用,load方法的完整格式是:

load( url, [data], [callback] )(注意没有参数是GET方式请求,有参数则是 POST方法)。

url:是指要导入文件的地址。

data:可选参数;因为Load不仅仅可以导入静态的html文件,还可以导入动态脚本,例如PHP文件,所以要导入的是动态文件时,我们可以把要传递的参数放在这里。
callback:可选参数;是指调用load方法并得到服务器响应后,再执行的另外一个函数。

缓存这东西,在一定程度上加快了页面的装载,但是也常常给我们带来麻烦。我在上篇文章里简单介绍了jQuery中Load方法的使用。在实际运用中,我们可能会碰到浏览器缓存的问题。

比如我就在IE7里碰到这个问题。

jQuery Load样本代码:

$(document).ready(function(){

$("#labels").load("/blog/categories/labels.html");
//在页面装载时,在ID为#labels的DOM元素里插入labels.html的内容。

});

当我更新了labels.html以后,在IE7里load方法仍旧在使用旧的labels.html,就算我按刷新键也不管用。好在jQuery提供一个防止ajax使用缓存的方法,把下面的语句加在head的javascript文件里,就可以解决问题。

$.ajaxSetup ({

cache: false //关闭AJAX相应的缓存

});

此外我再介绍几种方法解决缓存的方法。注意:我没有在jQuery load的问题上测试过,这些方法仅供参考!

1.更改文件名,比如把labels.html改成lables_new.html,但是这是没有办法的办法,一般没有人这么做。

2.在labels.html后加上特定时间,比如lables.html?20081116。在实际工作中,在我更新css/javascript文件后,我都是用这种办法来防止文件被缓存。

3.在labels.html文件的顶部加入以下声明:

<META HTTP-EQUIV="Pragma" CONTENT="no-cache">

<META HTTP-EQUIV="Expires" CONTENT="-1">

4.load函数不仅可以调用HTML,也可以调用script,比如labels.php,可以在php文件里使用header函数:

<?php

header("Cache-Control: no-cache, must-revalidate");

?>

 
 
jQuery 定时局部刷新,setTimeout和setInterval的区别

jQuery如何定时局部刷新及setTimeout和setInterval的区别.建议不要使用setInterval,太耗内存,可以让卡到你死机的,不信你试试
代码:
< head >

< script src="jQuery/jquery-1.4.1.min.js" type="text/javascript" ></ script >

< script >

$( document ).ready(function () {
setInterval("startRequest()",1000);

//
建议不要用setInterval,太耗内存,可以让你卡到死机的,不信你试试
setTimeout("startRequest()",1000);
});

function startRequest()

{

$("#date").text((new Date()).toString());

}

< / script >

< / head >

setTimeout和setInterval的区别:
区别:
setTimeout()

从载入后延迟指定的时间去执行一个表达式或者是函数;

仅执行一次 ;和window.clearTimeout一起使用.
setInterval()

在执行时,它从载入页面后每隔指定的时间执行 一个表达式或者是函数;(功能类似于递归函数);和window.clearInterval一起使用.
补充说明:
这两个方法都可以用来实现在一个固定 时间段之后去执行JavaScript。不过两者各有各的应用场景。

最大区别就是,setTimeout方法不会每隔5秒钟就执行一 次showTime函数,它是在每次调用setTimeout后过5秒钟再去执行showTime函数。这

意味着 如果showTime函数的主体部分需要2秒钟执行完,那么整个函数则要每7秒钟才执行一次。 而setInterval却没有被自己所调用的函数所

束缚,它只是简单地每隔一定时间就重复执行 一次那个函数。

如果要求在 每隔一个固定的时间间隔后就精确地执行某动作,那么最好使用setInterval,而如果不想 由于连续调用产生互相干扰的问题,尤其

是每次函数的调用需要繁重的计算以及很长的处 理时间,那么最好使用setTimeout。
 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  JQuery