【问题标题】:Ionic 4: ion-chip activatable / clickable by default; how to turn off?Ionic 4:离子芯片默认可激活/可点击;如何关闭?
【发布时间】:2020-01-27 15:04:39
【问题描述】:

使用 Ionic 4 和 React,我有以下代码:

<IonChip color="success">
  <IonIcon icon={thumbsUp} />
  <IonLabel>{this.state.numCorrect}</IonLabel>
</IonChip>

默认情况下,这会在我的浏览器中呈现以下 DOM 内容:

<ion-chip color="success" class="ion-color ion-color-success ios ion-activatable hydrated">
  <ion-icon role="img" class="ios hydrated"> ... </ion-icon>
  <ion-label class="sc-ion-label-ios-h sc-ion-label-ios-s ios hydrated">0</ion-label>
</ion-chip>

如您所见,ion-activatable 类被自动添加到芯片组件中,这导致它看起来可点击并显示 Material Design 波纹效果等。但我不希望该组件可点击(我只是将它用作指标组件)。我可以以某种方式禁用这个类吗?

Ionic 4 的在线文档对此没有提供任何建议。

【问题讨论】:

    标签: javascript reactjs ionic4


    【解决方案1】:

    如果查看ion-chipWeb组件的implemetation,可以看到默认添加了ion-activatable类(只能在组件渲染后修改类和事件):

    export class Chip implements ComponentInterface {
      /**
       * The color to use from your application's color palette.
       * Default options are: `"primary"`, `"secondary"`, `"tertiary"`, `"success"`, `"warning"`, `"danger"`, `"light"`, `"medium"`, and `"dark"`.
       * For more information on colors, see [theming](/docs/theming/basics).
       */
      @Prop() color?: Color;
    
      /**
       * Display an outline style button.
       */
      @Prop() outline = false;
    
      render() {
        const mode = getIonMode(this);
    
        return (
          <Host
            class={{
              ...createColorClasses(this.color),
              [mode]: true,
              'chip-outline': this.outline,
              'ion-activatable': true,
            }}
          >
            <slot></slot>
            {mode === 'md' && <ion-ripple-effect></ion-ripple-effect>}
          </Host>
        );
      }
    }
    

    因此,您可以做一个简单的解决方法,即使用pointer-events CSS 属性防止ion-chip 元素上的所有单击、状态和光标选项(如果您不想要涟漪效应,请仅使用&lt;IonChip mode="ios"&gt;待渲染):

    ion-chip {
      pointer-events: none;
    }
    

    【讨论】:

    • 谢谢,我明白了。 Ionic 4 开发人员不会将此作为可配置属性公开,而是将其硬编码为 true,这让我有点失望。看起来很简单,可以暴露...
    猜你喜欢
    • 2020-04-16
    • 2019-10-25
    • 1970-01-01
    • 1970-01-01
    • 2019-09-24
    • 2019-09-02
    • 2019-06-13
    • 2019-02-27
    • 1970-01-01
    相关资源
    最近更新 更多