我目前正在开发一个CMS,PHP和JavaScript(+ AJAX)之间有很多通信。我在整个流程中存储变量时遇到了困难。
例如:登录后,您可以选择要编辑的网站。单击时,我将site_id存储在POST变量中。之后,我重定向到pages-overview-page,在那里我使用这个site_id从数据库中读出了我的所有页面。
如果我添加页面,则会发生以下情况:
1. $ _POST ['site_id']通过回显放入javascript:
echo "<script>var siteid =".$_POST['siteid'].";</script>"
2.我的JavaScript然后进行AJAX调用:
$(".leftpanelinner").on('click','._add-page', function(event){
event.preventDefault();
$(".sortable").load("ajax_scripts/page-actions.php/add_page",{siteID: siteid, callFunction:'add_page' });
});
3.这就是它发出一个php脚本,它向网站添加一个页面,查询我的数据库,然后重新加载我页面的主要部分:
public function new_page($iSite_id, $sTemplate, $sTitle, $sMeta, $sCSS, $sJS, $sFavicon, $aContent, $aMenu)
{
$oPagemodel = new page_model;
$iPage_id=$oPagemodel->insert_pagemodel($iSite_id, $sTemplate, $sTitle, $sMeta, $sCSS, $sJS, $sFavicon, $aContent, $aMenu);
return $iPage_id;
}
public function insert_pagemodel($iSite_id, $sTemplate, $sTitle, $sMeta, $sCSS, $sJS, $sFavicon, $aContent, $aMenu)
{
$this->set_pagemodel($sTemplate, $sTitle, $sMeta, $sCSS, $sJS, $sFavicon, $aContent, $aMenu);
$sSQL = "INSERT INTO `pages` (f_site_id, object) VALUES ('".$iSite_id.', '.serialize($this)."');";
if (mysql_query($sSQL)) {$this->iID = mysql_insert_id();} else {return false;}
return $this->iID;
}
通过JavaScript / PHP / AJAX存储变量是不是更简单的方法,还是上面最好的方法?
答案 0 :(得分:0)
您可以使用Cookie。
<?php
$foo = 'lorem';
setcookie('the_foo',$foo,time() + (86400 * 7));
echo $_COOKIE['the_foo'];
?>
您也可以使用js获取和设置Cookie。