我正在尝试为我的 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.scss
var\Ext\Component.scss
也尝试使用workspace,但这种方式更适合在多个应用程序之间共享组件和主题。在这种情况下,组件可以作为一个包添加(如第一种方式的主题)。
最后,尝试将自定义组件添加到框架源中,但注意到 SenchaCMD 不支持这种方式。想想,这是不可接受的。