很多时候我们在用smarty时,并不希望缓存整个页面,例如天气、股票等这类即时更新的信息。那么我们可以让其不缓存,常见的实现有如下3种方法:
1.insert 法:
Insert 函数类似于 inluce 函数,不同之处是 insert 所包含的内容不会被缓存,每次调用该模板都会重新执行该函数。比如说我们定义一个显示时间的函数:
function insert_get_current_time() { return date("H:i:s"); } //然后在模板中: {insert name="get_current_time"}
这样每次打开页面,显示的都是即时时间,而不是缓存的。注意这里的函数名一定要以insert开头,模板中的name与之对应。如果我们的函数包含一些参数,那么我们的在模板中可以这样:
{insert name="get_current_time" lid=#banner_location_id# sid=#site_id#} //那么Smarty 调用该函数类似insert_get_current_time(array("lid"=>"12345","sid"=>67890"));
在smarty代码中:
function smarty_block_nocache($param,$content,$smarty) { return $content; } $smarty->register_block('nocache','smarty_block_nocache',false);
在模板文件中:
<{nocache}> //这里放不需要被缓存的内容 <{/nocache}>
3.插件block法:
这个跟block差不多,只是我们将其以插件的形式来做。在Smarty/plugins目录下建一个文件:block.nocache.php,这里命名一定要规范,否则smarty识别不了。 内容如下:
function smarty_block_nocache($param,$content,$smarty) { return $content; }
在模板中和上面一直,不需要被缓存的地方加上nocache就可以了!
本文向大家介绍smarty模板局部缓存方法使用示例,包括了smarty模板局部缓存方法使用示例的使用技巧和注意事项,需要的朋友参考一下 在开启smarty缓存的情况下,第一次执行时会将其编译好的输出文件保存到cache目录中,然后在程序中通过smarty的is_cache()函数检测其 cache文件是否过期,如果过期会更新缓存,如果没有过期会自动调用cache文件,这样就省去了编译的过程。检测c
本文向大家介绍PHP清除缓存的几种方法总结,包括了PHP清除缓存的几种方法总结的使用技巧和注意事项,需要的朋友参考一下 PHP清除缓存的几种方法总结 现在开发的项目是用tp3.1版本的,在开发过程中我们常常会遇到页面缓存的问题(特别是html的缓存);刷新后还是旧版的数,再刷新下还是旧版数据,慢慢的开始怀疑人生了,哈哈;所以在开发过程中我们又必要每次及时清除缓存。 清除缓存的方法大概有3种(都是实
本文向大家介绍js清除浏览器缓存的几种方法,包括了js清除浏览器缓存的几种方法的使用技巧和注意事项,需要的朋友参考一下 关于浏览器缓存 浏览器缓存,有时候我们需要他,因为他可以提高网站性能和浏览器速度,提高网站性能。但是有时候我们又不得不清除缓存,因为缓存可能误事,出现一些错误的数据。像股票类网站实时更新等,这样的网站是不要缓存的,像有的网站很少更新,有缓存还是比较好的。今天主要介绍清除缓存的几种
本文向大家介绍smarty缓存机制?相关面试题,主要包含被问及smarty缓存机制?时的应答技巧和注意事项,需要的朋友参考一下 如果开启了缓存,smarty同时生成一份静态的html页面,如果在设定的时间没有过期,再次访问的时候,你访问的就是是html文件了,减少了读取数据库,所以就效率来说,要高一些。
本文向大家介绍JavaScript中iframe实现局部刷新的几种方法汇总,包括了JavaScript中iframe实现局部刷新的几种方法汇总的使用技巧和注意事项,需要的朋友参考一下 Iframe是一种嵌入网页的框架形式,Web页面可以通过更改嵌入的部分,达到部分内容刷新。 Iframe的用法与普通的标签元素DIV类似,可以指定在页面中嵌入的位置、颜色、界面布局等 一、iframe实现局部刷新方法
本文向大家介绍列举几种瀑布流布局的方法相关面试题,主要包含被问及列举几种瀑布流布局的方法时的应答技巧和注意事项,需要的朋友参考一下 flex方法: .waterfall{ //从上到下 display: flex; flex-direction: row; } .column { //从左到右 display: flex; flex-direction: column; width: calc(1