【概念】
此函数将打开输出缓冲。
当输出缓冲激活后,脚本将不会输出内容(除http标头外),相反需要输出的内容被存储在内部缓冲区中。
内部缓冲区的内容可以用 ob_get_contents() 函数复制到一个字符串变量中。
想要输出存储在内部缓冲区中的内容,可以使用 ob_end_flush() 函数。
另外, 使用 ob_end_clean() 函数会静默丢弃掉缓冲区的内容。
【缓冲区的基本用法】
ob_start(); //打开缓冲区 ob_clean(); //清除缓冲区中的内容 ob_end_flush(); //冲刷出(送出)输出缓冲区内容并关闭缓冲
【基本的测试】
echo '1'; ob_start(); echo '2'; ob_clean();
结果: 1
解释:这是最简单的用法,那就是给不想输出内容的外面加上ob_start(),然后再清除缓冲区中的内容,这样就实现了咱们的使用场景。
我们可以选择性的输出自己想输出的。去掉自己不想输出的。
echo '1'; ob_start(); echo '2'; //输出缓冲区 ob_end_flush();
结果: 12
//打开缓冲区 ob_start(); echo '1'; //清除缓冲区,此时不会输出1 ob_clean(); //输出缓冲区。但是因为上面已经清除过缓冲区了,所以不会输出 1 ob_end_flush(); echo '2';
结果: 2
ob_start(); //打开缓冲区 echo '1'; $a = ob_get_contents(); //输出缓冲区内容到$a,相当于赋值给$a ob_clean(); //这里清除缓冲区内容 echo '2'; //输出2 echo $a; //输出$a
结果: 2 1
解释:这里的ob_get_contents();是获取缓冲区的内容。我们可以把获取的内容赋值给一个变量,这样,就算清除了缓冲区,我们输出变量,还是可以正常的输出1的。
【常用的地方】
该函数常用于页面静态化,构造微型web框架能起到很关键的作用,将渲染好的页面通过输入缓存的方式直接写入到一个文件,这样判断该文件是否存在即可实现用户本次访问需不需要去重新渲染一个页面,也可应用到大型项目中,用nosql去存储渲染好的页面,具体使用方法因人而异,看您喜欢哪种。