小编给大家分享一下bootstrap处理缓存问题的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
bootstrap处理缓存问题的方法:首先在关闭的时候清除数据;然后修改请求的URL,并在请求的URL上加上时间戳,语句如“function remoteUrl(u){...}”。
百度了一下,有很多类似的情况,解决办法基本都是如下两种:
1、在关闭的时候清除数据:
$("#myModal").on("hidden.bs.modal", function () {
$(this).removeData("bs.modal");
});
2、修改请求的URL,在请求的URL上加上时间戳。
function remoteUrl(u){
u += '&t=' + Math.random(1000)
$.get(u, '', function(data){
$('#remoteModal .modal-body').html(data)
})
$('#remoteModal').modal({show:true,backdrop:false})
}
上边的两个解决办法确实有效,但在IE中,第1种方法无效,第2种方法解决起来太繁琐。
我又百度到了另一种解决办法,专门针对IE的:
[OutputCache(NoStore = true, Duration = 0, VaryByParam = "*")]//不加的话,IE缓存会捣乱
该办法是要在服务器端给每个action加上,这样的话,这需要加多少action,那位作者居然嫌弃IE太垃圾了应该退出互联网界。
好了,吐糟完了,来上我的解决办法:直接修改bootstrap.js文件
位置在大约在1068行的位置,如下代码:
$(document).on('click.bs.modal.data-api', '[data-toggle="modal"]', function (e) {
var $this = $(this)
var href = $this.attr('href')
var $target = $($this.attr('data-target') || (href && href.replace(/.*(?=#[^\s]+$)/, ''))) //strip for ie7
var remoteUrl = !/#/.test(href) && href
if (remoteUrl == undefined) {
remoteUrl = "";
}
if (remoteUrl.indexOf("?") > -1) {
remoteUrl += "&" + (new Date()).valueOf()
}
else {
remoteUrl += "?" + (new Date()).valueOf()
}
//var option = $target.data('modal') ? 'toggle' : $.extend({ remote: !/#/.test(href) && href }, $target.data(), $this.data())
//上边的是原代码,增加了remoteUrl来解决IE下缓存的问题
var option = $target.data('modal') ? 'toggle' : $.extend({ remote: remoteUrl }, $target.data(), $this.data())
e.preventDefault()
$target
.modal(option, this)
.one('hide', function () {
$this.is(':visible') && $this.focus()
})
})
注释已经说明了解决办法,我只是增加了remoteUrl,在请求的url后加上时间,这样就不用一个一个的修改,也能兼顾各个浏览器了。
以上是“bootstrap处理缓存问题的方法”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。