diff options
author | xue <> | 2005-12-12 02:32:56 +0000 |
---|---|---|
committer | xue <> | 2005-12-12 02:32:56 +0000 |
commit | a7107dbd87aa92462a7348c1e73cd73da42cf4d8 (patch) | |
tree | aab6e973c2bfd2b1276187daee6ce8fbcfa54ce9 | |
parent | 5c2ac61fe0f0c892cd9934651d86a28b037a4386 (diff) |
Modified rendering logic of hidden fields so that they are rendered at both the beginning and ending of the form.
-rw-r--r-- | framework/Web/UI/TClientScriptManager.php | 14 | ||||
-rw-r--r-- | framework/Web/UI/TPage.php | 4 |
2 files changed, 14 insertions, 4 deletions
diff --git a/framework/Web/UI/TClientScriptManager.php b/framework/Web/UI/TClientScriptManager.php index 27029f56..cc5289c5 100644 --- a/framework/Web/UI/TClientScriptManager.php +++ b/framework/Web/UI/TClientScriptManager.php @@ -280,7 +280,9 @@ class TClientScriptManager extends TComponent public function registerHiddenField($name,$value)
{
- $this->_hiddenFields[$name]=$value;
+ // if the named hidden field exists and has a value null, it means the hidden field is rendered already
+ if(!isset($this->_hiddenFields[$name]) || $this->_hiddenFields[$name]!==null)
+ $this->_hiddenFields[$name]=$value;
}
public function registerOnSubmitStatement($key,$script)
@@ -365,8 +367,14 @@ class TClientScriptManager extends TComponent $str='';
foreach($this->_hiddenFields as $name=>$value)
{
- $value=THttpUtility::htmlEncode($value);
- $str.="<input type=\"hidden\" name=\"$name\" id=\"$name\" value=\"$value\" />\n";
+ if($value!==null)
+ {
+ $value=THttpUtility::htmlEncode($value);
+ $str.="<input type=\"hidden\" name=\"$name\" id=\"$name\" value=\"$value\" />\n";
+ // set hidden field value to null to indicate this field is rendered
+ // Note, hidden field rendering is invoked twice (at the beginning and ending of TForm)
+ $this->_hiddenFields[$name]=null;
+ }
}
if($str!=='')
$writer->write("<div>\n".$str."</div>\n");
diff --git a/framework/Web/UI/TPage.php b/framework/Web/UI/TPage.php index 2985e4d6..8d2c9686 100644 --- a/framework/Web/UI/TPage.php +++ b/framework/Web/UI/TPage.php @@ -694,7 +694,9 @@ class TPage extends TTemplateControl throw new TInvalidConfigurationException('page_singleform_required');
$this->_formRendered=true;
$this->_inFormRender=true;
- $this->getClientScript()->renderBeginScripts($writer);
+ $cs=$this->getClientScript();
+ $cs->renderHiddenFields($writer);
+ $cs->renderBeginScripts($writer);
}
/**
|