繁体   English   中英

Vuetify 扩展面板,面板标题左侧带有图标

[英]Vuetify Expansion Panels with icon on the left side of Panel's header

Vue.js 的 Vuetify 提供了一种将图标添加到扩展面板 ( https://vuetifyjs.com/en/components/expansion-panels#custom-icon ) 的方法。 但是,我希望将它们放在标题的左侧,如下面的屏幕截图所示。

扩展面板左侧的图标

CodePen仅显示了如何添加图标的方法,但在右侧。 我已经尝试了下面的 2 个片段,但没有任何成功。

<template v-slot:actions>
  <v-icon left>mdi-check</v-icon>
</template>

<v-icon left>mdi-check</v-icon>

两者都没有预期的结果。

接受的答案有效,但它破坏了图标旋转。 更好的方法可能是使用顺序:

<template>
    <v-expansion-panel-header>
        <template v-slot:actions>
            <v-icon class="icon">$expand</v-icon>
        </template>
        <span class="header">{{ headerText }}</span>
    </v-expansion-panel-header>
</template>

<style>
    .icon {
        order: 0;
    }

    .header {
        order: 1;
    }
</style>

https://github.com/vuetifyjs/vuetify/issues/9698#issuecomment-628132033

您可以通过将带有图标的标题面板标题包装在一个 div 中来实现相同的结果,如下所示:

 <v-expansion-panel-header class="justify-self-start" disable-icon-rotate>
     <div>
          <v-icon color="error">mdi-alert-circle</v-icon>
             <span>Item</span>
     </div>

</v-expansion-panel-header>

请检查这支

所以你不必用 CSS 来破解。

  <v-expansion-panel-header hide-actions>
    <template v-slot:default="{ open }">
      <div>
        <v-icon>
          <template v-if="open">mdi-chevron-up</template>
          <template v-else>mdi-chevron-down</template>
        </v-icon>
        Item
      </div>
    </template>
  </v-expansion-panel-header>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM