站长百科 | 数字化技能提升教程 数字化时代生存宝典
首页
数字化百科
电子书
建站程序
开发
服务器
办公软件
开发教程
服务器教程
软件使用教程
运营教程
热门电子书
WordPress教程
宝塔面板教程
CSS教程
Shopify教程
导航
程序频道
推广频道
网赚频道
人物频道
网站程序
网页制作
云计算
服务器
CMS
论坛
网店
虚拟主机
cPanel
网址导航
WIKI使用导航
WIKI首页
最新资讯
网站程序
站长人物
页面分类
使用帮助
编辑测试
创建条目
网站地图
站长百科导航
站长百科
主机侦探
IDCtalk云说
跨境电商导航
WordPress啦
站长专题
网站推广
网站程序
网站赚钱
虚拟主机
cPanel
网址导航专题
云计算
微博营销
虚拟主机管理系统
开放平台
WIKI程序与应用
美国十大主机
编辑“
Gallery:按事件的外观主题覆盖
”
人物百科
|
营销百科
|
网赚百科
|
站长工具
|
网站程序
|
域名主机
|
互联网公司
|
分类索引
跳转至:
导航
、
搜索
警告:
您没有登录。如果您做出任意编辑,您的IP地址将会公开可见。如果您
登录
或
创建
一个账户,您的编辑将归属于您的用户名,且将享受其他好处。
反垃圾检查。
不要
加入这个!
= 按事件的外观主题覆盖= 如果每相册外观主题和外观主题设定不够灵活以致无法满足你的需要的话,你可以注册一个事件侦听器来覆盖外观主题,该外观主题应被用于显示当前视图(页面)。 == 举例 == === 定义一个事件侦听器(Event Listener) === <pre> /*定义一个事件侦听器来决定使用那个外观主题*/ class MyThemeEventListener /* extends GalleryEventListener */ { function handleEvent($event) { global $gallery; $data = $event->getData(); $item = $event->getEntity(); if ($gallery->isEmbedded() && $data['viewType'] == VIEW_TYPE_SHOW_ITEM) { $themeId = 'nzdi'; } else if {$data['viewType'] == VIEW_TYPE_ADMIN) { $themeId = 'matrix'; } else { // 让其对此请求使用已配置的外观主题 $themeId = null; } return array(null, array('themeId' => $themeId)); } } </pre> === 注册事件侦听器=== ==== 在模块中==== <pre> /* 在module.inc中 */ function performFactoryRegistrations() { return GalleryCoreApi::registerFactoryImplementation('GalleryEventListener', 'MyThemeEventListener ', 'mymoduleid', 'modules/mymoduleid/classes/MyThemeEventListener.class', 'mymoduleid', array('Gallery::LoadThemeAndParameters')); } </pre> ==== 对于整合==== <pre> /* 在整合代码中*/ $ret = GalleryEmbed::init(...); ... /* 路径仅当时间侦听器(class MyThemeEventListener)尚未定义时相关。*/ $ret = GalleryCoreApi::registerFactoryImplementationForRequest('GalleryEventListener', 'MyThemeEventListener ', 'myintegration', '/../relative/path/to/my/integration/integrationCode.php', 'myintegration', array('Gallery::LoadThemeAndParameters')); ... $data = GalleryEmbed::handleRequest(); ... </pre> 注意还有稍简单但欠灵活的备用方法: <pre> /*在整合代码中*/ $ret = GalleryEmbed::init(...); ... $ret = GalleryEmbed::setThemeForRequest('siriux') ... $data = GalleryEmbed::handleRequest(); ... </pre> == Gallery::LoadThemeAndParameters 事件定义== 在核心API 7.40 / 嵌入API 1.3中介绍了此事件。 === 事件数据=== * 'viewType':为其中之一:VIEW_TYPE_MODULE|VIEW_TYPE_SHOW_ITEM|VIEW_TYPE_ADMIN|VIEW_TYPE_ERROR (常量) * 'viewName':具有Gallery视图名称的格式(与GalleryUrlGenerator::generateUrl()中的'视图'格式相同如,'core.ShowItem')。 === 事件实体 === * $event->getEntity()为当前页面返回null或GalleryItem。 === 返回值=== 返回值是与下列键相关联的一个数组: * 'themeId' 字串 – 此请求所用的外观主题的外观主题id。若要让Gallery使用已配置的外观主题而不是某个覆盖的话,就忽略此键或将其值设置为null。 * 'params'数组(可选)- 外观主题参量,也允许覆盖外观主题参量。如未被定义,特定外观主题的默认外观主题参量将被使用;反之参量应为无尽的。 == 外观主题参量的覆盖== 覆盖外观主题参量,让用户对外观主题进行配置使其用作override是有意义的。 参看一下keyalbum模块(modules/keyalbum/KeywordAlbumSiteAdmin.inc)来看看某外观主题设定页面是如何显示和处理的,以及设定是如何被存储的。 [[Category:Gallery 2:Development|Theme Override By Event]]
摘要:
请注意,您对站长百科的所有贡献都可能被其他贡献者编辑,修改或删除。如果您不希望您的文字被任意修改和再散布,请不要提交。
您同时也要向我们保证您所提交的内容是您自己所作,或得自一个不受版权保护或相似自由的来源(参阅
Wordpress-mediawiki:版权
的细节)。
未经许可,请勿提交受版权保护的作品!
取消
编辑帮助
(在新窗口中打开)