jQuery 定时局部刷新

时间:2022-03-11 07:59:28

<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。