首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如果我在后端设置项目并创建聚合物模板,则Vaadin-flow Grid不显示数据

如果我在后端设置项目并创建聚合物模板,则Vaadin-flow Grid不显示数据
EN

Stack Overflow用户
提问于 2019-03-13 23:13:15
回答 1查看 443关注 0票数 0

我在后端加载网格的数据并在聚合物模板中创建列时遇到了问题。列数正确,但不会显示任何数据。我真的会使用排序和过滤功能的vaadin-grid-column特性。我是不是漏掉了什么?我用vaadin 12和13试过了,我也用了Spring-boot 2.1.0版本

OrderListView.kt

代码语言:javascript
复制
@Tag("orderlist-view")
@HtmlImport("src/views/orders/orderlist-view.html")
@Route(CommanderConst.PAGE_ORDERS, layout = MainView::class)
class OrderListView(
        var orderGridDataProvider: OrderGridDataProvider
) : PolymerTemplate<TemplateModel>(), BeforeEnterObserver {

    @Id("orderGrid")
    private lateinit var orderGrid: Grid<OrderDTO>

    override fun beforeEnter(event: BeforeEnterEvent?) {
        orderGrid.dataProvider = orderGridDataProvider
    }
}

orderlist-view.html:

代码语言:javascript
复制
<link rel="import" href="../../../bower_components/polymer/polymer-element.html">
<link rel="import" href="../../../bower_components/vaadin-grid/vaadin-grid.html">
<link rel="import" href="../../../bower_components/vaadin-grid/vaadin-grid-column.html">
<link rel="import" href="../../../bower_components/vaadin-grid/vaadin-grid-filter.html">
<link rel="import" href="order-card.html">
<dom-module id="orderlist-view">
    <template>
        <vaadin-grid id="orderGrid" theme="no-row-borders" data-provider='{{myOrders}}'>
            <vaadin-grid-column>
                <template class="header">#</template>
                <template>[[index]]</template>
            </vaadin-grid-column>
            <vaadin-grid-column>
                <template class="header">id</template>
                <template>[[item.id]]</template>
            </vaadin-grid-column>
        </vaadin-grid>
    </template>
    <script>
        class OrderListView extends Polymer.Element {
            static get is() {
                return 'orderlist-view';
            }
            static get properties() {return {
               myOrders:{
                 type:Array
                 observer: '_myOrders'
               }
            }}

            _myOrders(o) {console.log(o);}

        }
        window.customElements.define(OrderListView.is, OrderListView);
    </script>
</dom-module>

然后看起来是这样的

但是如果我使用TemplateRenderer,并且在其中只使用了一些div,那么数据就会显示出来:

代码语言:javascript
复制
 orderGrid.addColumn(TemplateRenderer.of<OrderDTO>(
                "<order-show"
                        + "  header='[[item.header]]'"
                        + "  order='[[item.order]]'>"
                        + "</order-show>")!!
                .withProperty("order") { order -> order }
                .withProperty("header") { order -> order.id }
        )

order-show.html:

代码语言:javascript
复制
<dom-module id="order-show">
    <template>
        <div>
            <span>[[header]]</span>
        </div>
        <div>
            <h3>[[order.id]]</h3>
            <template is="dom-repeat" items="[[order.orderItems]]">
                <div>
                    <span>[[item.quantity]]</span>
                </div>
            </template>
        </div>
    </template>

    <script>
        class OrderCard extends Polymer.Element {
            static get is() {
                return 'order-show';
            }
        }

        window.customElements.define(OrderCard.is, OrderCard);
    </script>
</dom-module>

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-03-15 20:42:44

仅仅设置数据提供程序是不够的,您还需要让服务器端Grid组件知道服务器端数据的哪些部分应该实际发送到客户端。正如您所看到的,您为作为列添加的模板渲染器配置的任何属性都将被发布。在网格中还有一个专用的方法,您可以使用它来发布项目数据,而无需创建任何列:addValueProvider

在您的示例中,您可以添加如下内容(表示为Java,因为我的Kotlin不是很流利):

代码语言:javascript
复制
orderGrid.addValueProvider("header", order -> order.getId());
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55145262

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档