# style

back

# hover

back

单个无限定的按钮样式,无法覆盖框架自身的样式

.antd-pro-pages-one-map-comp-device-filter-customBtn {
  ...;
}
1
2
3

如下,则会覆盖掉框架中的样式

.antd-pro-pages-one-map-comp-alarm-detail-funcBtn
  .antd-pro-pages-one-map-comp-alarm-detail-customBtn {
  background: url()
    center no-repeat;
  background-size: 100%;
  color: #42eaec;
  border: none;
  height: 37px;
  font-size: 18px;
  width: 120px;
}
1
2
3
4
5
6
7
8
9
10
11

# 动态图片

back

/**
 * 根据设备告警类型,状态获取背景
 * @param {告警类型} status
 */
const findBackByStatus = (status) => {
  const backStyle = {
    backgroundRepeat: "no-repeat",
    backgroundPosition: "center",
    height: "374px",
    width: "316px",
    marginTop: "1rem",
    cursor: "pointer",
    color: "#ffffff",
  };
  if (alarmType.fire === status) {
    return { ...backStyle, backgroundImage: `url("${fireBackPng}")` };
  }
  if (alarmType.fault === status || alarmType.danger === status) {
    return { ...backStyle, backgroundImage: `url("${normalBackPng}")` };
  }
  return { ...backStyle, backgroundImage: `url("${offlineBackPng}")` };
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<div
  style={findBackByStatus(deviceData.lastStatus)}
  className={selectedDeviceId === deviceData.id ? styles.deviceTypeActive : styles.deviceType}
>
1
2
3
4

# 内联 style 不支持 important

back

加入 css 里面定义类如下

.bottom-60 {
  padding-bottom: 60px !important;
}
1
2
3

如果象下面这样定义 paddingBottom会被无视掉

<div
  className="bottom-60"
  style={{ marginTop: '-46px', paddingBottom: '0px !important' }}
>
1
2
3
4

要想让自定义的 paddingBottom 生效的方法如下

<div
  className="bottom-60"
  style={{ marginTop: '-46px' }}
  ref={(node) => {
    if (node) {
      node.style.setProperty('padding-bottom', '0px', 'important');
    }
  }}
>
1
2
3
4
5
6
7
8
9

# css module

尽量不要使用 less-loader 来处理 css 文件,在与 antd 一起使用时可能出现错误,单独写一条规则),所以我们只能两个来处理 css 的 loader。

修改config文件

  cssLoaderOptions: {
    modules: true,
    getLocalIdent: (
      context: {
        resourcePath: string;
      },
      _: string,
      localName: string,
    ) => {
      // 新增不需要作模块化处理的文件
      if (
        context.resourcePath.includes('node_modules') ||
        context.resourcePath.includes('ant.design.pro.less') ||
        context.resourcePath.includes('global.less') ||
        context.resourcePath.includes('tailwind.css')
      ) {
        return localName;
      }

      const match = context.resourcePath.match(/src(.*)/);

      if (match && match[1]) {
        const antdProPath = match[1].replace('.less', '');
        const arr = slash(antdProPath)
          .split('/')
          .map((a: string) => a.replace(/([A-Z])/g, '-$1'))
          .map((a: string) => a.toLowerCase());
        return `antd-pro${arr.join('-')}-${localName}`.replace(/--/g, '-');
      }

      return localName;
    },
  },
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33