4

我使用 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 的部分视图_form.php)和调用此视图的操作(updateAction)。然而,所有这些尝试并没有成功改变主题。Yii2 中是否有类似 CakePHP 中的方法,例如Configure::write($key, $value);

4

2 回答 2

4

您应该修改Yii::$app->assetManager->bundlesYii::$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'],
];
于 2015-01-23T13:16:28.460 回答
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/

通过这种方式,您可以使网站更易于维护,并且您不会为未来制造比您解决的问题更大的问题。

于 2015-01-23T20:59:14.073 回答