typecho插件编写教程3 - 保存配置
2023-06-13 09:16:16 时间
上一节我们制作了一个裸插件,下面我们开始让我们的插件开始工作!
完善方法
两个方法
我们实现activate
和deactivate
方法
public static function activate(){
return 'activate';
}
public static function deactivate(){
return 'deactivated';
}
如上代码所示,我们在激活和卸载插件方法中有返回值,所以在相应操作时会有相应的提示。
完善信息,使其更接地气
public static function activate(){
// do something
return '插件安装成功,请进入设置填写准入密钥';
}
public static function deactivate(){
// do something
return '插件卸载成功';
}
如何保存配置
准入密钥在哪里保存?当然是数据库了。
typecho已经为我们实现了Typecho_Widget_Helper_Form
类,我们只需要一点代码就可以摆脱需要自己写表单的烦恼了。
下图是表单类的继承关系,我们可以使用很多类型的表单来保存我们的选项。
下面我们在config
方法中保存 接口调用地址,类似如下链接(你可以在百度站长平台的链接提交里找到)
接口调用地址:http://data.zz.baidu.com/urls?site=www.phpgao.com&token=5wK0QtGCzdRzufvW
public static function config(Typecho_Widget_Helper_Form $form){
//保存接口调用地址
$element = new Typecho_Widget_Helper_Form_Element_Text('api', null, null, _t('接口调用地址'), '请登录百度站长平台获取');
$form->addInput($element);
}
初始化参数有5个,他们都是做什么的?
以下是表单基类的构造方法,他们的功能分别是表单输入项名称、选择项、表单默认值、表单标题、表单描述。
# var/Typecho/Widget/Helper/Form/Element.php:111
/**
* 构造函数
*
* @access public
* @param string $name 表单输入项名称
* @param array $options 选择项
* @param mixed $value 表单默认值
* @param string $label 表单标题
* @param string $description 表单描述
* @return void
*/
public function __construct($name = NULL, array $options = NULL, $value = NULL, $label = NULL, $description = NULL)
# 以下省略
使用需要注意的问题
- 修改表单名称($name)后需要重启插件才能工作,因为插件启用后,表单内容就持久化到数据库中了,禁用插件才能清空该插件的表单设置
- Typecho_Widget_Helper_Form_Element_Fake 不用理会
- 由
var/Widget/Plugins/Edit.php
我们学到很多表单的高级用法,以后老高会在合适的时候提到。
相关文章
- pycharm安装和环境配置_pycharm安装教程linux
- WOL(Wake On LAN – 局域网唤醒)外网唤醒 配置教程 远程开机「建议收藏」
- Django(39)使用redis配置缓存[通俗易懂]
- gradle安装教程_安卓gradle安装和使用配置
- pycharm配置python解释器的问题_python解释器的提示符
- 微信公众号服务号配置对接在线客服系统教程
- IDM脚本插件如何安装?及配置浏览器扩展教程
- PyQt5数据库开发1 4.3 QSqlTableModel 之 数据库表的建立与配置ODBC数据源
- Windows中IIS内FTP服务器高级配置教程
- 安装配置:Linux下安装tomcat8的最新图解教程
- Sql Server2012数据库使用IP登录服务器的配置教程
- 教你再linux下安装配置ffmpeg的详细教程
- Redis Sentinel服务配置流程(详解)
- MySQL5.7主从复制详细配置教程
- linux上传并配置jdk和tomcat的教程详解
- Oracle 10g安装配置方法图文教程
- MySQL Variables optimizer_prune_level 数据库 参数变量解释及正确配置使用
- C3P0配置MySQL:做到快速、灵活、可靠(c3p0配置mysql)
- Linux同步硬件时间:配置利器(linux同步硬件时间)
- Linux设置IP教程:轻松上手网络配置(怎么给linux设置ip)
- MySQL配置性能优化:获得最佳性能(mysql配置性能优化)
- Linux网络配置命令25字中文文章标题:学习Linux网络命令(附配置教程)(linux配置网络命令)
- Redis主从配置:加速数据同步(redis的主从配置)
- 本地Redis服务器的配置与部署(本地redis的配置)
- MyEclipse配置SQLServer2008数据库驱动操作步骤
- sqlserverdriver配置方法jdbc连接sqlserver
- IOS开发教程之put上传文件的服务器的配置及实例分享
- Windows2008R2IIS7.5配置FTP图文教程