javascript - ionic 4 : ion-chip activatable/clickable by default; how to turn off?

标签 javascript reactjs ionic4

将 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 的在线文档没有对此提供任何建议。

最佳答案

如果你看implemetation ion-chip的Web组件,可以看到ion-activatable默认添加class(只能在组件渲染后修改class和事件):

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>
    );
  }
}

因此,您可以采取的一个简单解决方法是阻止 ion-chip 上的所有单击、状态和光标选项。带有 pointer-events 的元素CSS 属性(如果您不希望呈现链式 react ,则仅执行 <IonChip mode="ios">):

ion-chip {
  pointer-events: none;
}

关于javascript - ionic 4 : ion-chip activatable/clickable by default; how to turn off?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59922760/

相关文章:

javascript - 页面加载前的 Webpack SCSS "Flicker"

javascript - 如何将变量与 IPv4 正则表达式正确匹配

javascript - 最简单的表格条目编辑/添加/删除 Web 工具包(与 php 一起使用)

javascript - 如何找到我的 typescript/react 模块的声明?

javascript - 以编程方式从 API 数据创建 Gatsby 页面

angular - Ionic 4 - 平板电脑上的点击与触摸启动(点击/移动配置问题)

javascript - 将 header 添加到 JavaScript WCF 服务调用

javascript - react 函数返回未定义

angular - ionic 4 - ionic cordova build android --prod 不会将 Angular 环境.prod 复制到环境中

angular - 发现很难将控制台上显示的数据显示在 View 中