Maison > Article > développement back-end > smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!
首先,各位大神,咱们就不纠结在应该不应该把php代码嵌入smarty模板中这类问题了,好不?因为我也是在别人代码上增加功能,只要能快速解决问题,啥办法都行。
问题描述:
在表格中,采用foreach的方式从$items读取每个记录,并且在表格中每行显示若干关键词相应的内容。$items是来自于后端php代码处理的结果。现在我需要在显示某个关键词内容时加个判断,读取相应内容,并且做个小链接。
代码如下:
{foreach $items as $item} {strip}。。。。。。。。。。。。。。。。。。。。。。。。。。。。{if $item->kind == "folder"} <td class="name"><p><a href="/Views/Regions/{$item->id}">{$item->name}</a></p></td> {elseif $item->type != "link"} <td class="name"><p><a href="/Regions/Files/Download/{$item->id}">{$item->name}</a></p></td> {else} {$link_content=""} {$this_id=$item->id} {$search_link_query="select * from archive.file where id='$this_id'"} {$con = mysqli_connect("localhost","root","root")} {$result = mysqli_query($con,$search_link_query)} {mysqli_close($con)} {$row=mysqli_fetch_row($result)} {$link_content=$row[8]} <td class="name"><p><a href="{$link_content}" target="_blank">{$item->name}</a></p></td> {/if}................................................... {/strip} {/foreach}
这个可以写在PHP里面,然后用用标签替换掉啊,在模板里面写什么连接数据库呢?
还是改你php吧 吧要添加的内容循环添加进去 页面直接调用就行了
感谢关注啊,我第一次用smarty,还是在别人代码基础上增加新功能。
不知道楼上所说的用标签替换掉,怎么替换掉?我也考虑过采用如下方式传送变量:
$smarty->assign("action", $action);
$smarty->display("folders.tpl");
在我看来,上面的方面只能是一次性的传送。但在我的表格中每条记录是不停的循环并且显示的,如果我要把前端每次循环的关键变量id传送到后端进行处理,那又应该如何做呢?
那问题就归结为: smarty模板中前端采用一个循环来显示内容,那我如何把每次循环中的关键变量传到后端,经过处理后又把结果返回该循环中呢?
其实,想想逻辑上也不难,大神们,有代码例子么?这里叩谢了。
吧你的后台代码贴出来 标识好 我看看
其实,我就非常纳闷了,咋就出现这么多“1”呢?
与该smarty相对应的后端php 代码为:(我已经尽量加注释了)
<?phpload_module("folders");load_module("files");//该页面的基本功能就是在表格中显示某个区域里的文件或者文件夹,我要增加一个链接link,并且其他一些链接等功能$id = getParamStr("id"); //此处id应该是这表格所属区域的Id,与我的问题相联系的数据库中储存的文件或链接id不一样,这个是我的理解,我也是刚看这代码if ($action == "search") //对这个页面有两个动作,一个是search{ $search = postParamStr("search"); $folders = do_action("folders","search", array($search, $currentUser->allowedRegion)); $files = do_action("files","search", array($search, $currentUser->allowedRegion)); $smarty->assign("folder", NULL); $paths = array("Search Result"); $path = new stdClass(); $path->id = NULL; $path->name = "Search Result"; $smarty->assign("paths", array($path));}else //对这个页面的另一动作是正常显示{ $folders = list_items("folders", $id); $folder = get_item("folders", $id); $files = list_items("files", $id); $smarty->assign("folder",$folder); $paths = $folder->path; if ($currentUser->level == 2) { unset($paths[0]); $paths = array_values($paths); } $smarty->assign("paths", $paths);}$items = array_merge($folders,$files); //获取到显示记录,并把多个记录组合起来$items = sort_items($items); //排序功能$smarty->assign("items", $items);$smarty->assign("action", $action);$smarty->display("folders.tpl");?>
{if count($items) > 0} {foreach $items as $item} {strip} <tr class="light" style="display:table-row;border-bottom:1px solid #DADAE3;" id="{$item->id}"> {if $item->kind == "folder"} <td class="type"><p><img src="/Images/iconset/Folder2.png" title="folder"/ alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></p></td> {else} {if $item->type == "docx" || $item->type == "doc"} <td class="type"><p><img src="/Images/iconset/page_white_word.png" title="word document"/ alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></p></td> {else if $item->type == "xlsx" || $item->type == "xls"} <td class="type"><p><img src="/Images/iconset/page_white_excel.png" title="excel document"/ alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></p></td> {elseif $item->type == "pdf"} <td class="type"><p><img src="/Images/iconset/page_white_acrobat.png" title="PDF"/ alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></p></td> {elseif $item->type == "png" || $item->type == "gif" || $item->type == "jpg"} <td class="type"><p><img src="/Images/iconset/picture.png" title="png"/ alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></p></td> {elseif $item->type == "ppt" || $item->type == "pptx"} <td class="type"><p><img src="/Images/iconset/page_white_powerpoint.png" title="powerpoint document"/ alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></p></td> {elseif $item->type == "mp4"} <td class="type"><p><img src="/Images/iconset/film.png" title="movie"/ alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></p></td> {elseif $item->type == "link"} <td class="type"><p><img src="/Images/iconset/link.png" title="link"/ alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></p></td> {else} <td class="type"><p><img src="/Images/iconset/page_white.png" title="document"/ alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></p></td> {/if} {/if} {if $item->kind == "folder"} <td class="name"><p><a href="/Views/Regions/{$item->id}">{$item->name}</a></p></td> {elseif $item->type != "link"} <td class="name"><p><a href="/Regions/Files/Download/{$item->id}">{$item->name}</a></p></td> {else} {$link_content=""} {$this_id=$item->id} {$search_link_query="select * from archive.file where id='$this_id'"} {$con = mysqli_connect("localhost","root","goldmine")} {$result = mysqli_query($con,$search_link_query)} {mysqli_close($con)} {$row=mysqli_fetch_row($result)} {$link_content=$row[8]} <td class="name"><p><a href="{$link_content}" target="_blank">{$item->name}</a></p></td> {/if} <td class="creator"><p>{$item->createdByName}</p></td> <td class="created"><p>{$item->created}</p></td> <td class="modified"><p>{$item->lastUpdated}</p></td> <td class="visibility"><p>Visible</p></td> <td class="size"><p>{if $item->size > 1000} {round(($item->size / 1024), 1)}MB {else} {$item->size}KB</p></td> {/if}</p></td> {if $item->kind == "folder"} <td class="id" align="middle"><p><a href="JavaScript:void(0);" onclick="return popitup('/Views/Folders/{$item->id}/Move')"><img src="/Images/iconset/move.png" style="max-width:90%" / alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></a></p></td> {elseif $item->kind == "file"} <td class="id" align="middle"><p><a href="JavaScript:void(0);" onclick="return popitup('/Views/Files/{$item->id}/Move')"><img src="/Images/iconset/move.png" style="max-width:90%" / alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></a></p></td> {/if} {if $item->kind == "folder"} <td class="edit"><p><a href="/Views/Folders/Edit/{$item->id}"><img src="/Images/iconset/wrench2.png" style="max-width:90%" title="edit"/ alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></a></p></td> {elseif $item->kind == "file"} <td class="edit"><p><a href="/Views/Files/Edit/{$item->id}"><img src="/Images/iconset/wrench2.png" style="max-width:90%" title="edit"/ alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></a></p></td> {/if} <td class="remove"><p><a href="/Views/Folders/Delete/{$item->id}" {if $item->kind == "folder"} {if $item->folderCount > 0 || $item->fileCount > 0} onclick="JavaScript:return confirm('This folder is not empty. If you delete it all content will also be deleted. Do you still want to continue?');"><img src="/Images/iconset/cross.png" style="max-width:90%" title="delete" alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></a></p></td> {else} onclick="JavaScript:return confirm('Do you really want to delete this folder?');"><img src="/Images/iconset/cross.png" style="max-width:90%" title="delete" alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></a></p></td> {/if} {elseif $item->kind == "file"} <td class="remove"><p><a href="/Views/Files/Delete/{$item->id}" onclick="JavaScript:return confirm('Do you really want to delete this file?');"><img src="/Images/iconset/cross.png" style="max-width:90%"/ title="delete" alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" ></a></p></td> {/if} </tr> {/strip} {/foreach} {else} <tr><td colspan="10"><table> <tr valign="middle" > <td class="light"> {if $action != "search"} <img src="/Images/emptyfolder.png" style="max-width:90%"/ alt="smarty模板中嵌入php代码,出现啼笑皆非的错误,请大神帮助!" > {/if} </td> <td class="light"> {if $action == "search"} <br /> <h1>No files or folders could be found!</h1> {else} <h1>This folder is empty!</h1> {/if}
其实如果不管代码的话,我的问题归结下来就两个细节:
1. 在smarty模板中,怎么{$con = mysqli_connect("localhost","root","root")}就会产生这么多的“1”呢?表明连接数据库成功么?有无方法隐藏这个显示?
2.smarty模板中前端的循环,如果与后端php代码处理动态的进行数值传输呢?
我需要把每次循环中的关键变量传到后端,经过处理后又把结果返回该循环中呢,并且在该次循环中显示php传送过来的值。如果做到呢?
大神们,你们有办法解决么?希望给出代码示例,否则小弟不会做啊。谢谢啊。
奶奶的,我的语文是体育老师教的。
更正啊:在php代码部分,第一条注释为:
//该页面的基本功能就是在表格中显示某个区域里的文件或者文件夹,除文件和文件夹类型外我要增加一个类型:链接link,并且还增加其他一些与link链接这种类型相关的功能
模板中不要写逻辑代码,尽量都写到php中去。
2.smarty模板中前端的循环,如果与后端php代码处理动态的进行数值传输呢?
我需要把每次循环中的关键变量传到后端,经过处理后又把结果返回该循环中呢,并且在该次循环中显示php传送过来的值。如果做到呢? 交互不外乎两种,form提交到后端,或者ajax传值。
更正:
多次测试后,发现是{mysqli_close($con)}这句话产生了“1”,其结果为
如过是{mysqli_close($con)}这句话产生了“1”
那就把 {mysqli_close($con)} 删掉
xu版主来了,欢迎啊。
我就是这么干的,确实没有“1”了。但这么干,不会产生什么坏影响吧?比如,与数据库的链接占用内存?对系统还产生其他影响?
但细想想,应该没有多大事情,因为系统都采用$con这个表示链接,最多也就一个变量占用内存而得不到释放?
徐版主,这样删掉没有大问题吧?
如过是{mysqli_close($con)}这句话产生了“1”
那就把 {mysqli_close($con)} 删掉
这是没有问题的
那好,徐版主说没有问题了,那大概八九不离十了。
结贴。
这是没有问题的