ThinkCMF5.1同樣強調`核心化`,`應用化`,`模板化`,`插件化`,這4點貫穿了整個ThinkCMF的開發過程,無論是 ThinkCMF官方團隊成員,還是 ThinkCMF開發者都應該深入理解這4點概念.
## 核心化
ThinkCMF一直以來都是遵循比較開放的開源協議,用戶可以隨意更改 ThinkCMF代碼為自己所用,這一點對開發者來說是很自由的,但是這會導致你自己修改過的 ThinkCMF升級困難,為了避免這一問題,我們希望在使用 ThinkCMF過程中,盡量保持 ThinkCMF的代碼不變.核心代碼就讓 ThinkCMF官方團隊來維護吧! 同時為了讓 ThinkCMF更完善,你應把自己想加的功能提交到[ ThinkCMF issue](https://github.com/thinkcmf/thinkcmf/issues) 里,同時到 官方VIP 群,或其他官方群@老貓.如果是 bug,你最好提交一個 github 的 PR,這樣你也成為了 ThinkCMF的貢獻者.
## 應用化
應用是 ThinkCMF一個獨立模塊,它負責完成一個場景下的需求,如:電商應用,論壇應用,話題應用,問答應用等; cmf 核心包含了 `admin`,`user`及`install`三個應用,`portal`應用是可以自己安裝卸載的;用戶可以根據自己的業務,開發適合自己的應用.
每個應用也會有自己的前臺,后臺,用戶邏輯,所有的應用代碼都應放到這個應用的目錄下,而不能在放在`admin`,`user`應用下,這兩個應用是核心應用,它們負責完成最基礎的后臺管理和用戶管理.
## 模板化
一個模板應該是可移植,用戶不用改任何代碼就可以使用的,它其實就是一個產品,可以批量銷售;我們不再希望開發者開發出來的模板,用戶需要改代碼才能讓用戶設置成自己的數據,開發者可以通過模板變量和模板控件的方式定義用戶可以更改的模板數據,讓模板在后臺可以設計;
cmf 默認提供了一個簡單的 bootstrap3的前臺模板,稍后官方會開發出更多的模板,開發者也可以開發自己的模板放到官網的模板市場中銷售;
ThinkCMF不僅前臺支持多模板,后臺也可以支持多模板,如果你覺得默認提供的后臺模板太 low,你也可以開發自己的后臺模板!
## 插件化
插件是一個靈活的系統擴展機制,它可以安裝,卸載,啟用和關閉;系統,應用和模板都有自己的插件鉤子,用戶可以下載安裝各種插件,開發者也可以為這些插件鉤子制作各種插件;插件同樣也是一個小產品,開發者可以把自己的插件放到官方的插件市場上銷售.
- 序言
- 基礎
- 安裝ThinkCMF
- 為了更爽
- 目錄結構
- 入口文件
- 第三方庫
- 開發規范
- 數據庫規范
- 調試模式
- URL訪問
- 應用
- 配置
- 路由
- 控制器
- 控制器定義
- 控制器模板賦值
- 控制器模板渲染
- 前臺控制器
- 前臺用戶控制器
- 后臺控制器
- 跳轉,AJAX返回和重定向
- URL生成
- 請求
- 請求信息
- 輸入變量
- 請求類型
- 獲取請求頭信息
- 偽靜態
- 更多
- 系統函數
- cmf_auth_check 用戶權限檢查
- cmf_captcha_check圖片驗證碼驗證
- cmf_check_mobile 檢查手機號
- cmf_check_user_action 用戶訪問控制
- cmf_check_verification_code 數字驗證碼檢查
- cmf_clear_cache清空系統緩存
- cmf_clear_verification_code 清除數字驗證碼
- cmf_compare_password 用戶密碼比較
- cmf_current_lang 判斷當前語言包
- cmf_generate_user_token生成用戶token
- cmf_get_admin_style 獲取后臺風格
- cmf_get_content_images 獲取HTML圖片
- cmf_get_current_admin_id 登錄管理員ID
- cmf_get_current_admin_theme獲取當前后臺模板
- cmf_get_current_theme獲取前臺當前模板
- cmf_get_current_user 獲取登錄用戶信息
- cmf_get_current_user_id 登錄用戶ID
- cmf_get_domain返回帶協議的域名
- cmf_get_file_download_url 獲取文件下載鏈接
- cmf_get_file_extension 獲取文件擴展名
- cmf_get_image_url 獲取圖片 URL
- cmf_get_option 獲取系統配置
- cmf_get_plugin_class 獲取插件類名
- cmf_get_plugin_config獲取插件配置
- cmf_get_root 網站根目錄
- cmf_get_site_info 獲取網站信息
- cmf_get_theme_path獲取前臺模板根目錄
- cmf_get_upload_setting獲取上傳配置
- cmf_get_user_avatar_url 獲取用戶頭像URL
- cmf_get_verification_code 生成數字驗證碼
- cmf_is_android 判斷是否為安卓手機
- cmf_is_ios 判斷是否為ios訪問
- cmf_is_ipad 判斷是否為ipad訪問
- cmf_is_iphone 判斷是否為iphone訪問
- cmf_is_mobile 判斷是否為手機
- cmf_is_user_login 判斷用戶是否登錄
- cmf_is_wechat 判斷是否為微信
- cmf_password 密碼加密
- cmf_plugin_url 插件URL生成
- cmf_random_string隨機字符串生成
- cmf_replace_content_file_url 替換編輯器文件地址
- cmf_scan_dir 替代scan_dir的方法
- cmf_send_email 發送郵件
- cmf_set_dynamic_config 設置動態配置
- cmf_set_option 設置系統配置
- cmf_split_sql 切分SQL文件
- cmf_update_current_user 更新當前用戶信息
- cmf_url_encode 生成base64的url
- cmf_verification_code_log 驗證碼發送日志
- cmf_version獲取版本號
- get_client_ip 獲取客戶端IP地址
- hook 添加鉤子
- 數據庫
- 數據庫配置
- 添加數據
- 更新數據
- 查詢數據
- 刪除數據
- 事務操作
- 更多數據庫操作
- 模型
- 模型定義
- 添加數據
- 更新數據
- 查詢數據
- 刪除數據
- 應用
- 應用的概念
- 應用開發流程
- 導航共享
- 幾個重要基類
- 后臺菜單注解
- 用戶操作配置
- URL 規則配置
- 應用第三方庫
- API
- 規范
- 狀態碼說明
- 版本號
- 資源控制器模板
- 成功返回
- 錯誤返回
- API路由
- API基類控制器
- API應用開發流程
- API第三方庫
- 模板
- 模板常量
- 模板標簽
- 變量輸出
- 系統變量
- 請求參數
- 使用函數
- 使用默認值
- 使用運算符
- 三元運算
- 原樣輸出
- 模板注釋
- 模板目錄
- 包含文件
- 模板布局
- 模板繼承
- 網站信息
- 內置標簽
- 循環輸出標簽
- 比較標簽
- 條件判斷
- 標簽嵌套
- 原生PHP
- 定義標簽
- CMF標簽
- 導航標簽
- 子導航標簽
- 驗證碼標簽
- 幻燈片標簽
- 鉤子標簽
- 友情鏈接標簽
- 分頁標簽
- 傻瓜式模板
- 什么是傻瓜式模板
- 模板描述文件
- 模板文件配置
- 模板變量類型
- 模板變量數據源
- 導航模板數據源
- 導航菜單模板數據源
- 幻燈片模板數據源
- 模板切換
- 插件
- 插件鉤子
- 核心鉤子
- 前臺模板鉤子
- 后臺鉤子
- send_mobile_verification_code
- comment
- guestbook
- admin_dashboard
- switch_theme
- admin_login
- admin_init
- home_init
- 插件類主文件
- 插件開發流程
- 插件配置
- 插件控制器
- 插件后臺管理控制器
- 插件后臺菜單
- 插件視圖
- 插件數據庫模型
- 插件多語言
- 插件API控制器
- 插件第三方庫
- 插件URL生成
- 前端
- Wind.js
- 前端組件
- js-ajax-form
- js-ajax-delete
- js-ajax-dialog-btn
- js-count-btn
- js-date
- js-datetime
- js-bootstrap-date
- js-bootstrap-datetime
- 專題
- 緩存
- Session
- Cookie
- 分頁
- 驗證碼
- 文件上傳
- 第三方擴展
- Swoole
- 附錄
- 升級日志
- 升級指導