我一直试图弄清楚这一点。这是很久以前别人写的代码,现在我被要求添加一些新功能。简而言之,有一个表单提交到 mysql db 并生成填充字段的 pdf。有可能返回并编辑表格并重新创建 pdf。
我的任务是在表单中添加两个复选框。一切正常,复选框值被发送到数据库,并在选中或未选中复选框的情况下创建 pdf 文件。
但是,当我返回编辑表单时,复选框始终处于未选中状态,它不会从数据库中获取值。
因此,填写表格的现有代码如下所示。我看到有文本、文本区域和选择...如何在此处添加复选框?谢谢您的帮助!
function fillEoi($eoiFile, $oldPost="NULL") {
if (is_array($oldPost) && count($oldPost)>2) {
$handle = fopen($eoiFile, "r");
$contents = fread($handle, filesize ($eoiFile));
fclose ($handle);
$tempName = tempnam("/tmp", "FOO");
$handle = fopen($tempName ,"w");
$fileContent=explode("\n",$contents);
foreach ($fileContent as $key => $item) {
//Get fieldname;
unset($fieldName);
$fieldName=strrev(stristr(str_replace("/", "\/", $item),"DB_"));
$fieldName=strrev(substr(strrchr($fieldName,"'"),1));
// If is an input field
if (stripos($item, "type='text'") && stripos($item, $fieldName)) {
//if (stristr($item, $fieldName))
// $valueAdd=" value='".$oldPost[$fieldName]."'";
$oldPost[$fieldName] = (strpos($item,'DB_INSUREDVALUE')) ? showValue($oldPost[$fieldName]) : $oldPost[$fieldName];
$item=str_replace($fieldName, $fieldName."' value='".$oldPost[$fieldName]."",$item);
} elseif (stripos($item, "</textarea>") && stripos($item, $fieldName)) {
// If is an Textarea
$item=str_replace("</textarea>", $oldPost[$fieldName]."</textarea>" , $item);
} elseif ((stripos($item, $fieldName) && stripos($item, "<select"))) /* or $selectField==1)*/ {
$returnVar['EoiDate'][$fieldName]=$oldPost[$fieldName];
}
}
$fileContent[$key]=$item;
}
$newContent=implode("\n",$fileContent);
fwrite ($handle, $newContent);
fclose($handle);
$newEoiFile=$tempName;
unset($eoiFile);
} else {
$newEoiFile=$eoiFile;
}
$returnVar['EoiPath']=$newEoiFile;
return $returnVar;
}