本文目錄一覽:
- 1、thinkphp 模板繼承問題
- 2、PHP類繼承的問題,子類繼承父類,實例化子類,先執行父類還是先執行子類?
- 3、php 繼承一個類一定要引用一下嗎
- 4、thinkphp5.1,類繼承問題請問我的為什麼是錯的。class Index extends \think\Controller?
- 5、php中靜態類的繼承
- 6、PHP繼承的問題,調用父類的方法this指向問題。
thinkphp 模板繼承問題
thinkPHP對模板文件進行目錄劃分,默認的模板文件定義規則是:視圖目錄/[模板主題/]控制器名/操作名+模板後綴。默認的視圖目錄是模塊的View目錄(模塊可以有多個視圖文件目錄,這取決於你的應用需要),框架的默認視圖文件後綴是.html。新版模板主題默認是空(表示不啟用模板主題功能)。在每個模板主題下面,是以模塊下面的控制器名為目錄,然後是每個控制器的具體操作模板文件,例如:User控制器的add操作對應的模板文件就應該是:View/User/add.html一些其他配置:1.’DEFAULT_V_LAYER’=’Template’,//設置默認的視圖層名稱//結果:Template/User/add.html2.’TMPL_TEMPLATE_SUFFIX’=’.tpl’,//設置默認後綴//結果:View/User/add.tpl3.’TMPL_FILE_DEPR’=’_’,//配置模板的目錄層次//結果:View/User_add.html4.’DEFAULT_THEME’=’default’,//設置默認的模板主題//沒有啟用模板主題之前View/User/add.html//啟用模板主題之後View/default/User/add.html
PHP類繼承的問題,子類繼承父類,實例化子類,先執行父類還是先執行子類?
不是這個意思。所謂「實例化子類的對象前要先實例化父類中的內容,為父類初始化」,是指當子類正在實例化時,總是鏈式調用父類構造方法初始化父類空間。換句話說,子類的構造方法必須先調用父類的構造方法,完了才能幹別的初始化工作。如果子類沒有顯式調用語句,編譯器會隱式幫你加上。
如:
public class A{ public A() { }}public class B extends A{ public B() { }}等價於:
public class A{ public A() { super();//這裡實際上是Object(); //其他初始化工作 }}public class B extends A{ public B() { super();//這裡實際上是A(); //其他初始化工作 }}另外,如果有這種情況:
public class A{ X x=new X(); public A() { }}public class B extends A{ Y y=new Y(); public B() {//這是類A空間里的欄位都已經初始化完畢。 }}在成員y被賦值之前,x一定已經存在。換句話說,X x=new X();一定先於Y y=new Y();執行。
php 繼承一個類一定要引用一下嗎
php有自動載入類的功能,但是需要遵循一定的規則,並且需要額外的代碼支持實現。
對於你說的問題,較常見的情況是b.php裡面雖然沒有引用a.php,但是c.php可能引用了a.php及b.php。只要在一個php進程中保證引用了這些文件就行,引用位置是可變的。例如在第一行引用和在第二行引用沒有區別,只要在new之前引用過就好了。但是明顯這不是值得推薦的。
thinkphp5.1,類繼承問題請問我的為什麼是錯的。class Index extends \think\Controller?
單詞錯啦好幾個,field不是filed,assign不是assgin,這些都是方法名,是不可以錯的,還有這個錯誤提示的意思是變數未定義,你要檢查下相關的欄位是否存在。
php中靜態類的繼承
樓主這個問題跟靜態沒有多大關係,主要是繼承的概念沒有搞清楚,繼承一個類是將子類擁有了調用父類的方法和屬性的權利,並不是說將父類的方法複製到了子類中self方法相當於當前類的指針,你那樣調用相當於寫了
public static function test() {
parent::who();
}
這樣的代碼,所以才會出現那樣的結果
PHP繼承的問題,調用父類的方法this指向問題。
我來說一說:
【一】…………public(僅有)屬性和方法的繼承…………
class a{
public $var = ‘var a br/’;
public function m(){
echo ‘fun a br/’;
}
public function run(){
echo $this-var;
$this-m();
}
}
class b extends a{
public $var = ‘var b br/’;
public function m(){
echo ‘fun b br/’;
}
}
$li = new b();
$li-run();
echo ‘hr’;
var_dump($li);
輸出:
var b
fun b
————————————————————————————
object(b)[1]
public ‘var’ = string ‘var b br/’ (length=11)
在這段代碼中所表示的,是我們常見的一種繼承方式,同為公有屬性的$var 和公有方法m()
在這裡,$var和m()都被繼承並覆寫,實例化過後,內存中只有一個$var實例,通過var_dump($li);我們可以看到它。
【二】…………private(私有)屬性和方法的繼承…………
class a{
private $var = ‘var a br/’;
private function m(){
echo ‘fun a br/’;
}
public function run(){
echo $this-var;
$this-m();
var_dump($this);
echo ‘br/br/’;
}
}
class b extends a{
private $var = ‘var b br/’;
private function m(){
echo ‘fun b br/’;
}
public function run(){
echo $this-var;
$this-m();
var_dump($this);
echo ‘br/br/’;
parent::run();
}
}
$li = new b();
$li-run();
echo ‘hr’;
var_dump($li);
輸出:
var b
fun b
object(b)[1]
private ‘var’ = string ‘var b br/’ (length=11)
private ‘var’ (a) = string ‘var a br/’ (length=11)
.
.
var a
fun a
object(b)[1]
private ‘var’ = string ‘var b br/’ (length=11)
private ‘var’ (a) = string ‘var a br/’ (length=11)
.
————————————————————————————————
object(b)[1]
private ‘var’ = string ‘var b br/’ (length=11)
private ‘var’ (a) = string ‘var a br/’ (length=11)
這個時候,我們可以看到,在調用run方法時,首先它會調用到b類的私有屬性$var 和私有方法m(),隨後,又使用parent::run()調用父類的run()方法,我們可以看到,父類的run()方法調用後,它所調用的屬性和方法,都是a類的兩個私有屬性和方法,這種形式,和你的問題一致;
而它與$this指向無關,我們可以在這裡看到,兩個$this都是指向b類。
而最有意思的是,在$li句柄中,我們卻看到了兩個屬性!一個是b類的屬性,一個是a類的屬性,這兩個屬性同時存在著,那麼,私有方法也自然是同時存在著。
【三】…………私有屬性和方法能不能被繼承…………
class a{
private $var = ‘var a br/’;
private function m(){
echo ‘fun a br/’;
}
}
class b extends a{
public function run(){
echo $this-var;
$this-m();
}
}
$li = new b();
$li-run();
輸出:
Notice: Undefined property: b::$var in E: … on Line 9
Fatal error: Call to private method a::m() from context ‘b’ in E: … on Line 10
這可以證明,私有屬性和方法,無法被繼承,所以,你的代碼示例中所說,將a類的m()方法更改為private後,會顯示aa的屬性,也就可以理解明白了。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/181859.html