微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sap – 使用具有声明性html视图的html片段

我正在尝试将大型html视图分解为更小,更易于管理的块.

是否可以使用片段来做到这一点?

例如,我有一个包含以下内容的片段文件(view.configurator.Summary.fragment.html):

<div data-sap-ui-type="sap.m.Button" data-text="Hello"></div>

在我的父文件中,我尝试按如下方式包含片段:

<div data-sap-ui-type="sap.m.VBox" class="summary-panel-content">

                <div data-sap-ui-type="sap.ui.core.Fragment"
                     data-fragment-name="view.configurator.Summary" 
                     data-type="HTML"></div>

            </div>

但是我在控制台中收到以下错误

Please provide a fragment name

有任何想法吗?

谢谢,

碣.

编辑:似乎它是一个错误,但您可以通过将片段包装在自定义控件中来解决

sap.ui.core.Control.extend("sap.mic.controls.Fragment",{

    Metadata: {
        properties: {
            "name": "string"
        }
    },init: function () {
    },renderer: function (renderManager,control) {
        var fragmentName = control.getProperty("name"),fragment = sap.ui.htmlfragment(fragmentName);

        renderManager.renderControl(fragment);
    }
});

像这样使用:

<div data-sap-ui-type="sap.m.Page" data-enable-scrolling="false">

    <div data-sap-ui-type="sap.mic.controls.Fragment"
         data-name="view.configurator.Summary"></div>

</div>

解决方法

在XML-View中

您必须将此命名空间添加到XML-Header中:

xmlns:mvc="sap.ui.core.mvc"

然后包含以下视图:

<mvc:XMLView viewName="your.namespace.ViewName"></mvc:XMLView>

在HTML视图中

您可以包含以下视图:

<div data-sap-ui-type="sap.ui.core.mvc.HTMLView" data-view-name="your.namespace.ViewName"></div>

XML视图中的XML片段

<core:Fragment id="xmlInXml" fragmentName="my.useful.SimpleUiPart" type="XML" />

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。