淺談初步理解鉤子,並且開發插件 (onethink)

以下爲我個人理解,僅供參考;

首先聊聊鉤子吧,其實,剛開始接觸onethink時,我也挺暈的,後面發現,這個鉤子 和 我曾經用的一個博客系統裏面的掛載點 很像!甚至就可以說,鉤子就是掛載點

掛載點:在系統中提供給你一個掛載點,我們可以進行插件開發,開發完成後,我們將其掛載到 掛載點上,會自動調用執行

列如吧。我們看內容頁的模版裏面有這樣的一段代碼
  1. {:hooks('documentDetailAfter')}
複製代碼
這個的意思就是:相當於在這邊 打一個點 ,我們可以將插件掛載到那

官方的說法是:文檔末尾顯示顯示的 鉤子

意思就是說,在文檔末尾的時候,會自動調用掛載在那個 鉤子 上的插件,那麼,我們就來簡單做一個小插件



其他的信息,隨意定義 ,我這邊寫的是 版權 

那個是否需要配置,反正我是沒有選,因爲選上以後,他存的配置文件,會被轉義。

需要實現的方法,就是 要我們掛載到哪了。我選的 documentDetailAfter

然後點擊確定,跳轉到插件列表。你會看到我們新建的插件


然後,也會在根目錄下的 Addons 下給我們生成一個插件目錄


我們在插件列表,點擊安裝

然後看我文檔末尾,也就是 文章 末尾處,還是沒有任何東西的


這時候,我們進入給我們生成的插件目錄裏邊 裏面有兩個文件 
插件名Addons.class.php
config.php

一個是插件主文件,一個是插件配置文件

我們打開主文件。看下面的註釋,我們就知道怎麼做啦。就是你需要開發什麼樣的插件,代碼寫在那邊就好了,鉤子會自動調用的


我們最簡單的輸出一句話 “鉤子也就那麼回事”
然後,文章頁,一看,出來了!


只要是模版中有這個 掛載點 ,也就是 鉤子,都會自動調用這個插件,然後輸出
  1. {:hooks('documentDetailAfter')}
複製代碼
接下來演示,模版調用
我們在插件目錄,建立一個html文檔,因爲這邊是在文章中調用的,所以名字爲 Article.html


然後在裏面直接 display調用即可


文章頁面此時就輸出我們的模版啦!




接下來,我們講一下,配置文件的使用
我們打開,官方的一個插件,點擊設置,可以看到如下設置項


但是,打開我們的插件時候,沒有設置項。這是因爲我們剛剛新建插件的時候,是否需要配置,沒有選上

我們打開我們的插件配置文件,發現裏面是空的,我們就自己添加吧!

首先,官方提供了一個很小的demo
  1. <?php
  2.  return array(
  3.     'random'=>array(//配置在表單中的鍵名 ,這個會是config[random]
  4.         'title'=>'是否開啓隨機:',//表單的文字
  5.         'type'=>'radio',         //表單的類型:text、textarea、checkbox、radio、select等
  6.         'options'=>array(         //select 和radion、checkbox的子選項
  7.             '1'=>'開啓',         //值=>文字
  8.             '0'=>'關閉',
  9.         ),
  10.         'value'=>'1',             //表單的默認值
  11.     ),
  12.  );
複製代碼
其實挺簡單的,我們就來用用,在配置文件中,添加我們的配置項
  1. <?php    
  2.     return array(
  3.         'name'=>array(
  4.             'title'=>'網站名稱:',
  5.             'type'=>'text',
  6.         ),
  7.         'url'=>array(
  8.             'title'=>'網站地址:',
  9.             'type'=>'text',
  10.         ),
  11.     );
複製代碼
然後,在插件列表中,點擊設置,看到沒,出來咯!


現在,我們只需要把我們填寫的配置項,同步到模版就好啦!
額,沒有文檔,只能看官方的插件,我發現一個方法
  1. $this->getConfig();
複製代碼
從字面上的意思來理解,就是獲取我們的配置信息,我試了試


結果的確是這樣做的,在文章中打印出了我們的配置項


!!!前提是,在設置中,我們填寫了這些信息


接下來,我們只要把它傳遞到模版中就好啦!


模版中


一個簡單的插件,就這樣好了,不知道你對於鉤子,怎麼理解

現在,再來講講鉤子
現在有一個需求:需要在我的首頁文章列表中,標題後面加上我的網址


其實也很簡單

首先我們新增一個鉤子 ,url 

然後,把他掛載到我們需要掛載的地方去
掛載的語法是:
  1. {:hooks('鉤子名')}
複製代碼
我們找到首頁模版,加上就好


然後捏:在插件管理中,新建一個插件,掛載到這個 url 鉤子上。方法都是一樣的

結尾,在說說鉤子的原理吧。有人把他比作爲 釘子 ,
我是這樣看的。js大家知道吧?js給一個按鈕,添加點擊事件彈出aaa後,點擊一下,就會彈出aaa。

這裏的,添加綁定事件 就等於 添加 鉤子

當系統執行時,發現那裏 有一個鉤子, 就會自動調用 掛載在 鉤子下的插件


文采不好,大家湊合着看哈~~~~


說了這麼多。要不要考慮給我來個 推薦。精華啥的 (*^__^*) 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章