2

我正在尝试为我的 ExtJS 应用程序创建一个自定义组件(使用 extjs 6.0 和现代工具包)

我已经生成了一个新应用程序并添加了一个新视图(扩展 Ext.Component),在那里放置了一些逻辑。我可以使用 xtype 创建这个组件,但会被主题化。

所以问题是:如何正确添加新组件(在框架源代码中/作为应用程序中的视图/其他地方)以及将组件放在哪里(生成自定义主题并将其插入那里/其他地方)?

组件(位于 app/view/components 文件夹中):

Ext.define("WebTest.view.components.IconButton", {
extend: 'Ext.Component',
xtype: 'iconbutton',

cachedConfig: {
    pressedCls: Ext.baseCSSPrefix + 'iconbutton-pressing',
    iconCls: null
},

config: {
    handler: null,
    scope: null,
    baseCls: Ext.baseCSSPrefix + 'iconbutton' + ' ' + Ext.baseCSSPrefix + 'iconalign-center'
},

template: [
    {
        tag: 'span',
        className: Ext.baseCSSPrefix + 'iconbutton-icon',
        reference: 'iconElement'
    }
],
............

添加:

我尝试了添加组件和主题的不同方法(目标是更改标准 CSS 并添加自定义)。

可接受的方式(对我来说)是将自定义组件放入ux.button folder(如@Alexander 提到的)并生成一个新的主题。由于使用了两个(在我的情况下)不同的命名空间,因此需要在主题package.json中清除命名空间参数。这提供了向标准组件添加自定义样式以及添加或覆盖标准组件(即)的机会src\MyAppNs\...\MyComponentClassName.scssvar\Ext\Component.scss

也尝试使用workspace,但这种方式更适合在多个应用程序之间共享组件和主题。在这种情况下,组件可以作为一个包添加(如第一种方式的主题)。

最后,尝试将自定义组件添加到框架源中,但注意到 SenchaCMD 不支持这种方式。想想,这是不可接受的。

4

1 回答 1

1

是否要在下方Ext或下方添加组件<YourAppNamespace>取决于您。您甚至可以为您的自定义组件库创建一个特殊的 lib 命名空间。

我建议命名组件<Namespace>.ux.button.IconButton

<YourAppNamespace>.ux.button.IconButtongo intosass/src/ux/button/IconButton.sass的样式,intoExt.ux.button.IconButton的样式ext/modern/your-selected-theme/sass/src/ux/button/IconButton.sass

我还没有尝试使用 lib 命名空间,也不知道将 CSS 放在哪里。

于 2015-11-26T20:21:24.190 回答