Vaadin Почему мой setvisible не работает?Дизайн всегда показан - PullRequest
0 голосов
/ 05 декабря 2018

Я работаю над Maven, Vaadin с Designer, и я не могу решить, почему мой код все еще показывает мне «test» и «test2», потому что через testView2.setVisible (false) метка «test2» должна быть скрыта,Вот весь соответствующий код.Надеюсь, что кто-нибудь может помочь.

TestView.java

@Tag("test-view")
@HtmlImport("src/views/kunde/test-view.html")
@Route("test")
public class TestView extends PolymerTemplate<TestView.TestViewModel> {

@Id("testView2")
private TestView2 testView2;

    public TestView() {
         testView2.setVisible(false);
    }

    public interface TestViewModel extends TemplateModel {
    }
}

test-view.html

<dom-module id="test-view"> <template>
<style include="shared-styles">
:host {
    display: block;
}
</style>
<div>
    <label>Label</label>
</div>
<test-view-2 id="testView2"></test-view-2> 
</template> <script>
        class TestView extends Polymer.Element {
            static get is() {
                return 'test-view';
            }
            static get properties() {
                return {
                    // Declare your properties here.
                };
            }
        }
        customElements.define(TestView.is, TestView);
    </script> </dom-module>

test-view-2.html

<dom-module id="test-view-2">
<template>
<style include="shared-styles">
        :host {
            display: block;
        }
    </style>
<div>
    <label>test2</label>
</div>
</template>
<script>
    class TestView2 extends Polymer.Element {
        static get is() {
            return 'test-view-2';
        }
        static get properties() {
            return {
                // Declare your properties here.
            };
        }
    }
    customElements.define(TestView2.is, TestView2);
</script>
</dom-module>

1 Ответ

0 голосов
/ 07 декабря 2018

Причина, скорее всего, заключается в том, что Flow использует атрибут hidden HTML при использовании setVisible(false).Но поскольку Designer по умолчанию добавляет :host { display: block; } к дизайну и https://meowni.ca/hidden.is.a.lie.html,, дизайн не будет подчиняться атрибуту hidden.

Вы можете обойти это, добавив следующие стили вручную в свойдизайн:

:host([hidden]) {
  display: none !important;
}
...