是否有可能将已经由PHP脚本回显的JS文件缓存到innerHTML或$('#id')。html(数据)元素如DIV?在将脚本源(js文件)输出到像
这样的元素之后,它会自动保存到访问者的缓存中可以在视图页面源中看到的脚本源属性(js文件/外部)可以保存到访问者的缓存中。 但是脚本源无法在页面源中看到,因为它需要AJAX响应,例如,它不会保存到访问者的缓存中。 (请参阅下面的我的代码/脚本)。
我已经多次尝试多次,更改JS文件内容,从alert()内部更改值,我基于alert(),然后刷新页面以查看警报消息将会发出什么,无论如何我输入了alert(),它显示了页面中的确切值,就像没有缓存保存..
我正在使用谷歌Chrome浏览器,我找到了一个ChromeCacheViewer,我看到http://my_host.com/SendCoins.js?_=13digits_here
有不同的数字..每当我点击相同的<a onclick="FUNCTION(showpage)">
,然后在另一个缓存文件中缓存历史记录将被添加http://my_host.com/SendCoins.js?_=another13digits
)..从缓存列表中,文件名是13位数。
请参阅图片:http://goo.gl/NEpvR9
缓存是一种临时存储(缓存)文档或数据的机制,以减少访问时间。
有可能吗?如果有,怎么样?
对不起,我无法解释清楚,或者我无法解释可以理解,但我可以提供我正在解释的例子。
例如 AJAX :( page.js)
function GoToPage(Page_Post)
var form_data = {
Page: Page_Post
};
$.ajax({
type: "POST",
url: "PAGE.php",
data: form_data,
success: function(data)
{
$('#PAGE').html(data); // innerHTML
}
});
}
AJAX :( sendcoins.js)
$(document).ready(function() {
$("form#sendcoins").submit(function() {
alert("Change this whenever you/visitor have used the GoToPage() and submitted the form"); //We will base on alert if it is really save to cache.
var form_data = {
Coins: $('#Coins').val()
};
$.ajax({
type: "POST",
url: "SendCoins.php",
data: form_data,
success: function(data)
{
$('#message').html(data); // innerHTML
}
});
});
});
HTML:
<a onclick="GoToPage('SendCoins')">Send Coins</a>
<div id=PAGE></div>
PHP:
<?php
$Page = $_POST[Page];
if( $Page == 'SendCoins' ){
......blah.....
echo '<script type="text/javascript" src="js/SendCoins.js"></script>';
echo '<img src="images/coin.png">';
echo '<form id="sendcoins" onsubmit="return false" >
<input type=number id=Coins> <input> submit .. blah.. blah..
</form>';
}
?>
因此,在回显到innerHTML的源文件之后,它将被保存到访问者的缓存中。
答案 0 :(得分:2)
您可以在ajax调用中使用cache参数。默认情况下,缓存属性设置为false,这就是您在请求中看到这些数字的原因。
例如:
$.ajax({
type: "POST",
url: "SendCoins.php",
data: form_data,
cache: true,
success: function(data)
{
$('#message').html(data); // innerHTML
}
});
有关缓存属性的更多信息,您可以看到here。