如何在 MessagePage 中将按钮图标改回正常大小?

How can I change button icons back to normal size inside of MessagePage?

因为我注意到我的按钮图标在其他视图中是正常大小,所以我猜这是因为 sap.m.MessagePage 元素。

对此是否有很好的解决方案,或者开发人员只是希望我们永远不要在该元素的按钮内使用图标? :D

globalThis.onUI5Init = () => sap.ui.require([
  "sap/ui/core/mvc/XMLView"
], async XMLView => (await XMLView.create({
  definition: document.getElementById("myxmlview").textContent,
  height: "100%",
})).placeAt("content"));
<script defer id="sap-ui-bootstrap"
  src="https://openui5.hana.ondemand.com/resources/sap-ui-core.js"
  data-sap-ui-oninit="onUI5Init"
  data-sap-ui-libs="sap.ui.core,sap.m"
  data-sap-ui-theme="sap_fiori_3"
  data-sap-ui-async="true"
  data-sap-ui-compatversion="edge"
  data-sap-ui-excludejquerycompat="true"
  data-sap-ui-xx-waitfortheme="init"
></script>
<!-- Issue fully reproducible with UI5 <= 1.87 and partially reproducible until 1.93 -->
<script id="myxmlview" type="text/xml">
  <mvc:View xmlns:mvc="sap.ui.core.mvc" xmlns="sap.m" displayBlock="true">
    <App>
      <MessagePage showHeader="false" icon="sap-icon://sap-ui5" text="UI5" description="sap.m.MessagePage">
        <buttons>
          <Button icon="sap-icon://message-warning" text="Change security settings" />
        </buttons>
      </MessagePage>
    </App>
  </mvc:View>
</script>
<body id="content" class="sapUiBody">
</body>

更新: 自 UI5 1.94 (commit: d90fbe7 / PR #3146).

以来,问题不再重现

上一个回答:

[...] did the developers just wanted us to never user icons inside of buttons in that element? :D

是的。 :P 根据 Fiori design guidelines in the topic "Button Content":

A button can contain an icon OR a text.

但是:即使没有文字,按钮图标看起来也不对:

这绝对是一个错误。刚刚在这里创建了一个问题:https://github.com/SAP/openui5/issues/3145