所以我知道我可以用css做到这一点,但我不想在主题附带的东西之外写任何CSS,因为我是原型。
@SpringComponent
@Scope( ConfigurableBeanFactory.SCOPE_PROTOTYPE )
class CharacterEditDialog extends VerticalLayout {
private static final long serialVersionUID = -2755765492408272282L;
private final transient CrudRepository<Character, Long> repository;
private final TextField name = new TextField();
private final TextField concept = new TextField();
private final TextField apparentAge = new TextField();
private final RichTextArea description = new RichTextArea();
private final RichTextArea biography = new RichTextArea();
private final RichTextArea appearance = new RichTextArea();
private final Button save = new Button( FontAwesome.SAVE );
private final Button cancel = new Button();
private final Button delete = new Button( FontAwesome.TRASH_O );
private final HorizontalLayout actions = new HorizontalLayout( save, cancel, delete );
@Autowired
CharacterEditDialog( final CrudRepository<Character, Long> repository ) {
this.repository = repository;
this.setMargin( true );
this.setSpacing( true );
this.save.setStyleName( ValoTheme.BUTTON_PRIMARY );
this.save.setClickShortcut( ShortcutAction.KeyCode.ENTER );
this.description.setWidth( 100, Unit.PERCENTAGE );
this.biography.setWidth( 100, Unit.PERCENTAGE );
this.appearance.setWidth( 100, Unit.PERCENTAGE );
}
Component edit( final Character entity ) {
BeanFieldGroup.bindFieldsUnbuffered( entity, this );
this.save.addClickListener( ComponentUtils.runAndCloseWindow( () -> repository.save( entity ) ) );
this.delete.addClickListener( ComponentUtils.runAndCloseWindow( () -> repository.delete( entity ) ) );
return this;
}
@PostConstruct
void init() {
FormLayout layout = new FormLayout( );
layout.addComponent( createTopRow() );
layout.addComponents( appearance, description, biography );
HorizontalLayout actionBarWrapper = new HorizontalLayout( actions );
actionBarWrapper.setWidth( 100, Unit.PERCENTAGE );
actionBarWrapper.setDefaultComponentAlignment( Alignment.MIDDLE_RIGHT );
this.addComponents( actionBarWrapper, layout );
}
Component createTopRow() {
HorizontalLayout topRow = new HorizontalLayout( name, concept, apparentAge );
topRow.setDefaultComponentAlignment( Alignment.MIDDLE_RIGHT );
topRow.setSpacing( true );
topRow.setWidth( 100, Unit.PERCENTAGE );
return topRow;
}
}
我希望action
栏中的所有按钮在布局中右对齐。查看dom时我可以看到actionBarWrapper
是全宽,并且组件被组合在一起,但是对齐似乎没有完成其工作
答案 0 :(得分:0)
解决方案是在第一个元素之前添加间隔符。
Component createTopRow() {
Label spacer = new Label();
spacer.setWidthUndefined();
HorizontalLayout topRow = new HorizontalLayout( spacer, name, concept, apparentAge );
topRow.setExpandRatio(spacer, 1);
topRow.setSpacing( true );
topRow.setWidth( 100, Unit.PERCENTAGE );
return topRow;
}