我使用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
的部分视图)和操作< / strong>调用此视图(updateAction)。但是,所有这些尝试都没有成功改变主题。在Yii2中是否存在CakePHP中的方法,例如Configure::write($key, $value);
?
答案 0 :(得分:2)
您应该修改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 :(得分:1)
你要解决这个问题,你想通过一些控制来单独改变1个控制器的JUI主题。您正在将2个css文件应用于网站的不同部分,这些部分也有可能在布局中更改样式。你找到的解决方案有效,但这是非常糟糕的做法。
如果您只想更改一些控件,请使用JUI范围以正确的方式执行。
以下是一些可以帮助您的链接:
http://www.filamentgroup.com/lab/using-multiple-jquery-ui-themes-on-a-single-page.html
http://jqueryui.com/download/
通过这种方式,您可以更轻松地维护网站,并且不会为您的未来创造更大的问题。