要了解两者之间的区别
render(),
renderAjax()首先您需要了解其
render()工作原理。
基本上,当
render()被称为每一件JS和CSS代码和文件引用的观点注册聚集在多个阵列将在适当的地方后呈现-
这些地方都存储在布局和他们的代码是通过调用渲染
beginPage(),
head(),
beginBody(),
endBody()和
endPage()。
您可以通过在相关方法中设置第二个参数来指出应在何处呈现JS代码,例如:
$this->registerJs("alert()", yiiwebView::POS_HEAD);渲染
<script type="text/javascript">alert()</script>
在方法所在的布局中
$this->head()。
一切工作正常,直到您只想渲染视图的主要部分而没有布局。没有它(及其方法
beginPage()),就无法以以前的方式呈现JS和CSS引用,这就是为什么这个花哨的jQuery代码旋转正方形不起作用的原因-
那里没有包含JS库。
当您
$this->render()从视图内 调用或仅从
$this->renderPartial()控制器调用时,确实发生了这种情况-
布局未应用。
renderAjax()
现在来救援。
这种方法不关心布局,因为它调用
beginPage(),
head(),
beginBody(),
endBody()并
endPage()通过自身的方法。因此,每个JS代码段都可以附加到呈现的视图上,并且即使需要在AJAX弹出窗口中完成,jQuery库也可以再次旋转该正方形。



