2013-03-09 72 views
0

我有一些正常工作的PHP代碼。不過,我想輸出Dropdownlist到我的TPL文件。我怎樣才能做到這一點?輸出Dropdowlist到TPL文件

<?php 

mysql_connect("$host", "$username", "$password")or die("cannot connect"); 
mysql_select_db("$db_name")or die("cannot select DB"); 

$sql="SELECT * FROM $tbl_name ORDER BY SORT_ORDER ASC"; 
$result=mysql_query($sql); 
if ($result === false) { echo "An error occurred."; } 

?> 

<html> 
<head> 
<title></title> 
</head> 
<body> 
<select name="usrname" id="usrname"> 
<option>Select employ</option> 
<?php 
while($rows=mysql_fetch_array($result)){ 
?> 
<option value="<? echo $rows['ID']; ?>"><? echo $rows['TITLE']; ?></option> 
<?php 
} 
mysql_close(); 
?> 
</select> 
</body> 
</html> 

回答

1
<option value="<? echo $rows['ID']; ?>"><? echo $rows['TITLE']; ?></option> 

而忘php text in <?php .... ?> ..please更改此代碼這樣的..

<option value="<?php echo $rows['ID']; ?>"><?php echo $rows['TITLE']; ?></option> 
+0

這不是我的意思。我想我需要分配它: $ tpl - >分配 我想從.tpl拉起它而不是PHP。 – user2063873 2013-03-09 07:19:27

0

你這是什麼意思.tpl?

你可以轉移你「而(...){...}」部分到另一個文件(說select.inc.php)和 包括它

,但如果你想有一個$ TPL對象在template.class.php先創建一個類,如:

class Template { 

    private $file; 
    public $result; 

    public function __construct($file) { 
     $this->file = $file; 
    } 

    public function display() { 
     ob_start(); 
     include $this->file; 
     ob_end_flush(); 
    } 
} 

包括它並創建模板文件select.tpl

<select name="usrname" id="usrname"> 
<? 
while($rows=mysql_fetch_array($this->result)) { 
?> 
    <option value="<?=$rows['id']?>"><?=$rows['name']?></option> 
<? 
} 
?> 
</select> 

最後創建的實例並調用display()方法在你的腳本:

$tpl = new Template('select.tpl'); 

$tpl->result = $result; 

$tpl->display();