php html登陆逻辑,保持演示文稿(HTML)和逻辑(PHP)分开
我試圖保持演示和邏輯分離,而不使用像Smarty這樣的模板引擎.到目前為止我所做的工作是有效的,但我不知道如果不在我的演示文稿中添加更多
PHP而不是我想做的事情.例如,現在我有這樣的事情:
product_list.php
try {
$query = $conn->prepare("SELECT p.id,p.name,p.description,IFNULL(url,title) AS url,GROUP_CONCAT(c.category SEPARATOR ',') AS category,FROM products p
LEFT JOIN product_categories pc ON p.id = pc.product_id
LEFT JOIN categories c ON pc.category_id = c.id
WHERE p.active = 1
GROUP BY p.id");
$query->execute();
$result = $query->fetchAll(PDO::FETCH_ASSOC);
}
catch (PDOException $e) {
echo $e->getMessage();
}
include('templates/product_list_tpl.php');
product_list_tpl.php
= $header_title; ?>
Category:?= $row['category']; ?>
在上面的例子中,一些產品將有一個類別,一些將具有多個.它們在逗號分隔列表中很好地顯示,但我想將類別名稱變為鏈接.我知道我可以做類似下面的事情,但對我來說似乎很麻煩.
= $div_title; ?>
= $row['title']; ?>
= $row['caption']; ?>
= $row['description']; ?>
Category:?
<?php foreach ($categories as $key => $category): ?>
= $category; ?>
= (sizeof($categories) > 1 && $key == end($categories)) ? ',?' : ''; ?>
Rating:?= $row['rating']; ?>
Rated?= $row['rated']; echo ($row['rated'] == 1) ? '?time' : '?times'; ?>
提前感謝您的任何建議.此外,如果任何人對我在示例代碼中使用的一般分離格式有任何輸入,我很樂意聽到它.我在休息8年后才開始重新編碼.
編輯:根據@Devon在評論中建議,在第三個代碼塊上添加了缺少的endforeach和改進的縮進.
編輯:我更新了第三個代碼塊,包括我之前遺漏的HTML,并添加了實現我正在尋找的輸出所需的所有PHP功能.它有效,但IMO這樣做可以消除我的分離.我現在基本上只有一個文件與我的數據庫調用和另一個文件與此混亂.我覺得我沒有朝著正確的方向尋找正確的業務邏輯/表示邏輯分離.
我哪里錯了?
總結
以上是生活随笔為你收集整理的php html登陆逻辑,保持演示文稿(HTML)和逻辑(PHP)分开的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 什么是算法
- 下一篇: matlab拟合不显示直线,新人求助一下