❶ php語法錯誤
這個是模板文件編譯後出現的語法錯誤,可以檢查模板文件有沒有寫法問題。
可以按提示的
D:phpStudyWWWMyRuntimeCacheHome.phpLINE:513
這個文件和行,對應找出模板文件出問題的地方,再檢查修復
❷ 一個完整的PHP類包含的七種語法說明
這篇文章主要介紹了一個完整的PHP類包含的七種語法說明,這些語法包括屬性、靜態屬性、方法、靜態方法、類常量、構造函數、析構函數,本文一一給代碼示例和詳細註解讓你快速了解類的寫法,需要的朋友可以參考下
類中的七種語法說明
-屬性
-靜態屬性
-方法
-靜態方法
-類常量
-構造函數
-析構函數
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
?php
class
Student
{
//
類里的屬性、方法和函數的訪問許可權有
(函數和方法是同一個概念)
//
private
私有的
protected
受保護的
public
公有的
//
類常量
沒有訪問許可權修飾符
const
STUDENT
=
'Tom';
//
屬性
public
$stu_name;
//
靜態屬性
public
static
$stu_num
=
1;
//
方法
public
function
stuFunction()
{
echo
'non_static_function','br
/';
}
//
靜態方法
public
static
function
static_stuFunction()
{
echo
'static_function','br
/';
}
//
構造函數
創建對象時自動調用
public
function
__construct($stu_name)
{
$this-stu_name
=
$stu_name;
echo
'__construct','br
/';
}
//
析構函數
銷毀對象時自動調用
public
function
__destruct()
{
echo
'__destruct','br
/';
}
}
//
實例化類對象
$object
=
new
Student('Tom');
//
對象調用屬性
echo
$object-stu_name,'br
/';
//
對象調用靜態屬性
echo
$object::$stu_num,'br
/';
//
類調用靜態屬性
echo
Student::$stu_num,'br
/';
//
使用對象分別調用方法和靜態方法
$object-stuFunction();
$object-static_stuFunction();
$object::stuFunction();
$object::static_stuFunction();
//
使用類分別調用方法和靜態方法
Student::stuFunction();
Student::static_stuFunction();
//
類調用類常量
echo
Student::STUDENT,'br
/';
總結:
對象可以調用方法和靜態方法,類可以調用方法和靜態方法。
❸ php 的框架與模板
樓主的認知不對哦,以下為樓主解惑:
框架:在php源碼的基礎上,開發者將常用的功能進行二次封裝形成的代碼集合,其本身往往不具備任何可用的功能,其目的僅僅是使開發人員可以基於框架更快的開發出符合要求的應用。例如,不使用框架開發一個用戶管理功能可能需要5天,使用框架可以將這個時間縮短到2天。實際上,對於任何一個項目,訪問控制、資料庫訪問、文件處理等功能都是必備的,框架就是將這些常用功能進行了更易用的封裝,避免開發人員在通用組件上重復開發,浪費時間。
模板:為了將PHP內容和html內容更好的分離為目的產生的一種應用,其主要目的是為了網頁製作人員可以不去學習PHP就能修改頁面的內容(可惜不學PHP還要學smarty,因此我個人並不覺得模板真的能帶來什麼實際的好處)
另外,如dede,DZ,PHPCMS等是基於PHP的產品,本身已經具備了大量的功能,安裝之後就能使用,當然,因為需求的不同可能需要在該產品的基礎上進行二次開發。
綜述,模板沒有太大的價值,完全可以在非用不可的時候再去學習,對於PHP開發人員來說,smarty可以立刻上手。它可以(也只能)被框架或PHP產品使用。框架是必須掌握的,定製性很強的項目必然都是基於框架開發的。PHP產品,如果你要開發的項目和某個PHP產品的功能達到80%以上的契合,那麼應該考慮基於該產品進行開發。
一些網站提供簡單的博客,留言板等的源碼,不基於框架的小項目實際上只能稱為練習,只有參考價值。
註:不是說不使用框架的項目就不算項目,事實上如果一個項目如果沒有使用某某框架,其項目的一部分代碼也必然的會具有框架的特徵,即自定義框架也是框架。
❹ 您好,我想問一下js文件里可以直接接收使用php的assign方法傳過來的值嗎看到您回答過類似問題,謝謝
首先確認下。php的assign應當是一種模板語法。
$this->assign('param',$param);
上述php一般和以下html模板成對出現
<p><{$param}></p>
那麼如果要在js中直接取值,只需在模板文件中如下編寫
<script>
varparam={$param}
</script>
注意:如果$param是字元串,則需要加引號。json和int都可不加
❺ 使用PHP程序檢查PHP文件是否有語法錯誤
在網上找了一下。剛開始以為 token_get_all()函數能處理語法錯誤的問題,結果發現,它只是做簡單的詞法分析。沒有辦法。後來到論壇上去問了一下
之前在當當的時候的一個項目中用到了一個簡單的模板引擎,其實也是借鑒discuz來做的模板引擎,很簡單,它所作的事情就是把一些自定義的標簽編譯成php代碼。已經說了很簡單了,所以編譯的時候也名優進行模板語法的檢查,那麼在開發過程中就會出現編譯出來的php文件有語法問題,有語法問題沒有關系,我修改重新編譯一下就好了。首先不能在每次請求的時候都把php模板重新編譯一下,會嚴重影響性能,折中的處理時在每個編譯好的php文件末尾檢查一下該模板文件是否已經修改過,根據設定的更新頻率,如果又需要則重新編譯模板文件,現在的問題是編譯出來的php文件自己有語法錯誤,根本執行不到模板檢查那一步,所以即使修改了模板文件中的問題也不會重新編譯。 所以我想尋找一種簡單的方法來檢查生成的php文件是否合法。不合法就重新編譯,這樣開發過程中就不用出現錯誤就得手動刪除緩存文件了。
在網上找了一下。剛開始以為 token_get_all()函數能處理語法錯誤的問題,結果發現,它只是做簡單的詞法分析。沒有辦法。後來到論壇上去問了一下
有人告訴我有這樣一個函數 php_check_syntax() 我想問題就這么堅決了。。我真應該rtf(read the fuck mannual). 仔細一看。這個函數已近被棄用了:
note: for technical reasons, this function is deprecated and removed from php. instead, use php -l somefile.php from the commandline.
這個technical reason 到底是什麼呢? 先不管了,以後再慢慢研究,反正不能使用這個方法就對了。
他們的建議是使用命令行$php -l filename.php 來檢查語法。
gary every給了我一個代碼片段參考:
在命令行下檢查問題也不大。如果我要放在在線應用呢? 這就涉及到可移植性的問題了。首先是操作系統,然後就是環境變數。這樣的話就會依賴於伺服器端的配置。在http://www.php.net/manual/en/function.php-check-syntax.php 上有人貼出了自己的php_check_syntax()函數實現。
有的採用的就是上面的命令行的方法。
後面有提到使用eval的方法來驗證。eval方法會執行傳入的代碼, 如果代碼有語法錯誤則會拋出parser error, 可以使用'@'錯誤抑制符去掉錯誤信息,eval和echo一樣並不是函數,不能使用變數函數的方法調用比如:
$func = 『eval'
$func()這樣的調用就是無效的。它會提示沒有eval函數,如果你自己定義這么一個函數也是有問題的。因為eval是一個關鍵字。
eval調用和include差不多,如果被包含文件中沒有明確return就返回null。如果直接eval我們需要檢查的文件會造成被檢查的文件內代碼被執行,這可不是我們想要的,我們只需要檢查一下這個文件的語法是否正確。 我們可以在要檢查的文件之前添加return 語句,讓代碼提前跳出,那麼後面的代碼就不會執行了。好的,就這么干。
checker.php
if(!function_exists('php_check_syntax')) {
function php_check_syntax($file_name, &$error_message = null) {
$file_content = file_get_contents($file_name);
$check_code = "return true; ?>";
$file_content = $check_code . $file_content . "<?php ";
if(!@eval($file_content)) {
$error_message = "file: " . realpath($file_name) . " have syntax error";
return false;
}
return true;
}
}
if(!php_check_syntax("file.php", $msg)) {
echo $msg;
}
else {
echo "woohoo, ok!";
}
file.php
<?php
foreach:: a => b
?>
因為parse error 是沒法被 set_error_handler處理函數處理的。這個異常沒辦法catch到。所以才使用了@來抑制錯誤。這帶來的問題就是我們無法得到詳細的錯誤信息。 不過目前我需要的功能也只是檢查語法是否正確。不正確的話重新編譯模板文件,就這么簡單,至於語法錯誤,在顯示網頁的時候自然會看得到。
❻ smarty模板中include和include_php的用法
我們可以在模板內載入PHP程序或者另一個子模板.分別可以使用include_php及include這兩個Smarty模板語法.俺習慣用include 啦.
在使用include 時,我們可以預先載入子模板,或者動態載入子模板.預先載入通常使用在有共同的文件標頭或者版權什麼的.而動態載入則可以用在同一的框架頁,這樣就可以換皮膚一樣換界面啦.兩者也可以同時混用.是情況八.
test.php---------
<?php
require "main.php";
$tpl->assign("title", "Include Test");
$tpl->assign("content", "這是模板1.htm的參數");
$tpl->assign("dyn_page", "3.htm");
$tpl->display('test.htm');
?>
模板templates下面
test.htm----------
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=big5">
<title><{$title}></title>
</head>
<body>
<{include file="1.htm"}><br />
<{include file=$dyn_page}>
<{include file="2.htm" custom_var="自己定義變數的內容"}>
</body>
</html>
1.htm----
<{$content}>
2.htm----
<{$custom_var}>
吃飯後繼續
OK,下面我將盡力解釋下include_php
include_php這個標簽通常用來在你的模板文件中include一個php文件.這個php文件一般在這個本地路徑的文件夾下面.include_php這個標簽必須有file這個屬性.用來包含應用php文件的路徑的人.可以是相對路徑,也可以是絕對路徑.{include_php file="/path/to/load.php"}
include_php是一種非常好的模板組建句柄.使php代碼和模板文件分離開來.舉例來說吧.比較直觀點.比如你有個模板是用來顯示你的網站導航的.當然導航的內容是動態的從資料庫中獲取.這時你可以將php聯接資料庫的獲取內容放在一個php文件中,然後在模板文件中include_php file=xxxxx.php這樣,你可以在任何地方應用這個導航模板.而不需要再次做聯結導航內容的工作啦.
通常,php文件默認只能包含一次.如果你一定要多次引用,那麼可以增加once屬性設置為false就可以拉.
給出實際例子啦(來自手冊)
function include_php
load_nav.php
-------------
<?php
// load in variables from a mysql db and assign them to the template
require_once("MySQL.class.php");
$sql = new MySQL;
$sql->query("select * from site_nav_sections order by name",SQL_ALL);
$this->assign('sections',$sql->record);
?>
index.tpl
---------
{* absolute path, or relative to $trusted_dir *}
{include_php file="/path/to/load_nav.php"}
{foreach item="curr_section" from=$sections}
<a href="{$curr_section.url}">{$curr_section.name}</a><br>
{/foreach}
---------
回答完畢,謝謝大家得掌聲.哇哈哈
❼ 急急急。PHP問題,提示 Smarty的模板語法編譯錯誤,怎麼解決
根據你貼出的報錯信息,可以判斷出你模版裡面用的分隔符(delimiter)不對,你看看你初始化smarty的時候left_delimiter 和right_delimiter 寫的什麼,比如我的配置如下:
'left_delimiter'=>'{%',
'right_delimiter'=>'%}',
那麼在模版里就寫:{%if $regularlist['total'] > 0%} aaa{%/if%}
❽ php類的語法說明
類是變數與作用於這些變數的函數的集合。使用下面的語法定義一個類:
<?php
class Cart { var $items; // 購物車中的物品
// 將 $num 個 $artnr 物品加入購物車
function add_item($artnr, $num) {
$this->items[$artnr] += $num;
} // 將 $num 個 $artnr 物品從購物車中取出
function remove_item($artnr, $num) {
if ($this->items[$artnr] > $num) {
$this->items[$artnr] -= $num; return true;
} elseif
($this->items[$artnr] == $num) {
unset($this->items[$artnr]); return true;
} else {
return false; }
}
} ?>
上面的例子定義了一個 Cart 類,這個類由購物車中的商品構成的數組和兩個用於從購物車中添加和刪除商品的函數組成。
<?php
class test {
?>
<?php
function test() {
print 'OK'; }
}?>
但是以下用法是可以的:
<?phpclass test { function test() { ?> <?php print 'OK'; }}?>
在 php 4 中,var 變數的值只能初始化為常量。用非常量值初始化變數,需要一個初始化函數,該函數在對象被創建時自動被調用。這樣一個函數被稱之為構造函數(見下面)。
<?php/* php 4 中不能這樣用 */class Cart { var $todays_date = date(Y-m-d); var $name = $firstname; var $owner = 'Fred ' . 'Jones'; /* 不過包含有常量的數組可以 */ var $items = array(VCR, TV);}/* 應該這樣進行 */class Cart { var $todays_date; var $name; var $owner; var $items = array(VCR, TV); function Cart() { $this->todays_date = date(Y-m-d); $this->name = $GLOBALS['firstname']; /* etc. . . */ }}?>
類也是一種類型,就是說,它們是實際變數的藍圖。必須用 new 運算符來創建相應類型的變數。
<?php$cart = new Cart;$cart->add_item(10, 1);$another_cart = new Cart;$another_cart->add_item(0815, 3);?>
上述代碼創建了兩個 Cart 類的對象 $cart 和 $another_cart,對象 $cart 的方法 add_item() 被調用時,添加了 1 件 10 號商品。對於對象 $another_cart,3 件 0815 號商品被添加到購物車中。
$cart 和 $another_cart 都有方法 add_item(),remove_item() 和一個 items 變數。它們都是明顯的函數和變數。可以把它們當作文件系統中的某些類似目錄的東西來考慮。在文件系統中,可以擁有兩個不同的 README.TXT 文件,只要不在相同的目錄中。正如從為了根目錄訪問每個文件需要輸入該文件的完整的路徑名一樣,必須指定需要調用的函數的完整名稱:在 php 術語中,根目錄將是全局名字空間,路徑名符號將是 ->。因而,名稱 $cart->items 和 $another_cart->items 命名了兩個不同的變數。注意變數名為 $cart->items,不是 $cart->$items,那是因為在 php 中一個變數名只有一個單獨的美元符號。
<?php// 正確,只有一個 $$cart->items = array(10 => 1);// 不正確,因為 $cart->$items 變成了 $cart->$cart->$items = array(10 => 1);// 正確,但可能不是想要的結果:// $cart->$myvar 變成了 $cart->items$myvar = 'items';$cart->$myvar = array(10 => 1);?>
在定義類的時候,無法得知將使什麼名字的對象來訪問:在編寫 Cart 類時,並不知道之後對象的名稱將會命名為 $cart 或者 $another_cart。因而你不能在類中使用 $cart->items。然而為了類定義的內部訪問自身的函數和變數,可以使用偽變數 $this 來達到這個目的。$this 變數可以理解為「我自己的」或者「當前對象」。因而 '$this->items[$artnr] += $num' 可以理解為「我自己的物品數組的 $artnr 計數器加 $num」或者「在當前對象的物品數組的 $artnr 計數器加 $num」。