本文介绍了Yii2:多个事件附加视图的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
嗨,
我想尝试制作一些动态侧边栏和内容,我在视图中多次触发事件,
这是我的代码:
Hi,
I want try to make some dynamic sidebar and content, I have trigger event multiple times in view,
here my code:
后端/视图/布局/_sidebar.php
use commoncomponentHook;
use yiiaseEvent;
Event::trigger(Hook::className(), Hook::SIDEBAR_MENU);
后端/视图/ext/index.php
use commoncomponentHook;
use yiiaseEvent;
Event::trigger(Hook::className(), Hook::PlUGIN_CONTENT);
common/component/Hook.php
namespace commoncomponent;
use yiiaseComponent;
class Hook extends Component{
const SIDEBAR_MENU = '';
const PlUGIN_CONTENT = '';
}
后端插件插件index.php
namespace backendpluginsPlugin;
use Yii;
use commoncomponentHook;
use yiiaseEvent;
use yiihelpersHtml;
class Index extends Event{
function sidebar() {
echo '<li>' . Html::a('Menu Plugin 1', ['/ext?n=Plugin']) . '</li>';
}
function renderContent(){
echo 'this is content';
}
}
Event::on(Hook::className(), Hook::SIDEBAR_MENU, [new Index, 'sidebar']);
Event::on(Hook::className(), Hook::PlUGIN_CONTENT, [new Index, 'renderContent']);
后端pluginsPlugin2index.php
namespace backendpluginsPlugin2;
use Yii;
use commoncomponentHook;
use yiiaseEvent;
use yiihelpersHtml;
Event::on(Hook::className(), Hook::SIDEBAR_MENU, function () {
echo '<li>' . Html::a('Menu Plugin 2', ['/ext?n=Plugin2']) . '</li>';
});
这里是我的控制器 backend/controller/ExtController.php
namespace backendcontrollers;
use Yii;
use yiiwebController;
class ExtController extends Controller
{
public function actionIndex(){
return $this->render('index');
}
}
问题:
- 为什么它们在_sidebar.php 中出现多次?我只是在sidebar.php 中触发了SIDEBAR MENU,为什么它们同时触发了SIDEBAR_MENU 和PLUGIN_CONTENT?
- 我在 backend/view/ext/index.php 中也有触发事件,但是没有触发 PLUGIN_CONTENT,所以内容没有出现
推荐答案
在hook.php中,它们都有相同的值,即空字符串"",它们必须有值
in hook.php, they both have same value, which is empty string "", they mush have value
namespace commoncomponent;
use yiiaseComponent;
class Hook extends Component{
const SIDEBAR_MENU = 'sidebarMenu';
const PlUGIN_CONTENT = 'pluginContent';
}
这篇关于Yii2:多个事件附加视图的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!