在控制器中覆盖 Yii2 assetManager 配置
Override Yii2 assetManager config in controller
我使用 yii-jui 在视图中添加一些 UI 元素,例如 datePicker。在 frontend\config\main-local.php
中,我设置了以下内容以更改 JqueryUI 使用的主题:
$config = [
'components' => [
'request' => [
// !!! insert a secret key in the following (if it is empty) - this is required by cookie validation
'cookieValidationKey' => 'gjhgjhghjg87hjh8878878',
],
'assetManager' => [
'bundles' => [
'yii\jui\JuiAsset' => [
'css' =>
['themes/flick/jquery-ui.css'],
],
],
],
],
];
我尝试了以下方法来覆盖控制器操作方法中的这个配置项:
public function actions() {
Yii::$app->components['assetManager'] = [
'bundles' => [
'yii\jui\JuiAsset' => [
'css' =>
['themes/dot-luv/jquery-ui.css'],
],
],
];
return parent::actions();
}
我还尝试将上面显示的 Yii::$app->components['assetManager']
的值设置为 视图本身 (它是表单 _form.php
的部分视图)和 调用此视图的操作 (updateAction)。然而,所有这些尝试都没有成功改变主题。 Yii2 中是否有类似 CakePHP 中的方法,例如 Configure::write($key, $value);
?
你应该修改Yii::$app->assetManager->bundles
(Yii::$app->assetManager
是一个对象,不是一个数组),例如
Yii::$app->assetManager->bundles = [
'yii\jui\JuiAsset' => [
'css' => ['themes/dot-luv/jquery-ui.css'],
],
];
或者,如果您想保留其他捆绑配置:
Yii::$app->assetManager->bundles['yii\jui\JuiAsset'] = [
'css' => ['themes/dot-luv/jquery-ui.css'],
];
你的做法全错了,你想为 1 个控制器单独更改 JUI 主题,因为有几个控件。您正在将 2 css 个文件应用到网站的不同部分,这些部分也有可能更改布局中的样式。您找到的解决方案有效,但这是非常糟糕的做法。
如果您只想更改一些控件,请使用 JUI 范围以正确的方式进行。
以下是一些对您有帮助的链接:
http://www.filamentgroup.com/lab/using-multiple-jquery-ui-themes-on-a-single-page.html
http://jqueryui.com/download/
通过这种方式,您可以使网站更易于维护,并且不会为未来造成比您解决的问题更大的问题。
我使用 yii-jui 在视图中添加一些 UI 元素,例如 datePicker。在 frontend\config\main-local.php
中,我设置了以下内容以更改 JqueryUI 使用的主题:
$config = [
'components' => [
'request' => [
// !!! insert a secret key in the following (if it is empty) - this is required by cookie validation
'cookieValidationKey' => 'gjhgjhghjg87hjh8878878',
],
'assetManager' => [
'bundles' => [
'yii\jui\JuiAsset' => [
'css' =>
['themes/flick/jquery-ui.css'],
],
],
],
],
];
我尝试了以下方法来覆盖控制器操作方法中的这个配置项:
public function actions() {
Yii::$app->components['assetManager'] = [
'bundles' => [
'yii\jui\JuiAsset' => [
'css' =>
['themes/dot-luv/jquery-ui.css'],
],
],
];
return parent::actions();
}
我还尝试将上面显示的 Yii::$app->components['assetManager']
的值设置为 视图本身 (它是表单 _form.php
的部分视图)和 调用此视图的操作 (updateAction)。然而,所有这些尝试都没有成功改变主题。 Yii2 中是否有类似 CakePHP 中的方法,例如 Configure::write($key, $value);
?
你应该修改Yii::$app->assetManager->bundles
(Yii::$app->assetManager
是一个对象,不是一个数组),例如
Yii::$app->assetManager->bundles = [
'yii\jui\JuiAsset' => [
'css' => ['themes/dot-luv/jquery-ui.css'],
],
];
或者,如果您想保留其他捆绑配置:
Yii::$app->assetManager->bundles['yii\jui\JuiAsset'] = [
'css' => ['themes/dot-luv/jquery-ui.css'],
];
你的做法全错了,你想为 1 个控制器单独更改 JUI 主题,因为有几个控件。您正在将 2 css 个文件应用到网站的不同部分,这些部分也有可能更改布局中的样式。您找到的解决方案有效,但这是非常糟糕的做法。
如果您只想更改一些控件,请使用 JUI 范围以正确的方式进行。
以下是一些对您有帮助的链接:
http://www.filamentgroup.com/lab/using-multiple-jquery-ui-themes-on-a-single-page.html
http://jqueryui.com/download/
通过这种方式,您可以使网站更易于维护,并且不会为未来造成比您解决的问题更大的问题。