ant-design二次封装-实现全屏弹窗

最近正在开发自己开源的通用爬虫的前端界面,用的是ant-design-pro进行的二次开发,遇到的坑还是很多的,因此接下来分享的内容大多都是和ant-design有关的,经验都来自于自己的填坑之旅。本篇我们来讲讲怎么实现Modal组件的全屏功能。

我们希望实现一下功能

  • 用户能够通过全屏控制图标进行全屏及非全屏操作
  • 支持初始全屏弹窗,支持隐藏全屏控制图标

寻找图标嵌入点

按照惯例,全屏控制图标都是放置在弹窗的头部区域,靠近关闭按钮附近。在浏览过官方组件使用文档之后,大致发现有两个地方可以实现此功能。

  • closeIcon
    此属性可以实现自定义关闭图标,我们在此处可以插入两个图标,一个用于关闭,一个用来控制全屏操作,同时防止全屏操作触发关闭指令,我们应该在后者的点击事件中阻止事件的冒泡。
  • title
    此属性用来展示标题内容。我们注意到它不仅支持字符串,也支持ReactNode类型的数据,因此我们可以在此处实现自定义图标,并通过样式控制悬浮到头部右侧。

嵌入控制图标

此处我们选择title属性来实现,通过增加一个中间层在用户传入的title中添加一个全屏控制弹窗

const { title } = this.props;
return (
      <>
        {title}
          <button
            type="button"
            className="ant-modal-close"
            style={{ right: 42 }}
          >
            <span className="ant-modal-close-x">
              <Icon className="ant-modal-close-icon" type="arrows-alt" />
            </span>
          </button>
      </>
    );

上述代码中的全屏控制按钮copy自弹窗中的关闭按钮,唯一的不同就是图标的位置及图标类型。我们将上述代码封装成一个函数,将其执行结果赋予modaltitle属性。
实现效果如下:

实现全屏控制功能

上述我们提到要实现用户能够自由控制全屏及退出全屏的功能。因此我们定义一个名为fullScreenstate属性来控制当前的弹窗状态。

// 切换当前全屏状态
toggleFullScreen = () => {
    const { fullScreen } = this.state;
    this.setState({
      fullScreen: !fullScreen,
    });
  };

titleRender = () => {
  const { title } = this.props;
  const { fullScreen } = this.state;
  return (
      <>
        {title}
          <button
            type="button"
            className="ant-modal-close"
            style={{ right: 42 }}
            onClick={this.toggleFullScreen}
          >
            <span className="ant-modal-close-x">
              <Icon className="ant-modal-close-icon" type={fullScreen ? 'shrink' : 'arrows-alt'} />
            </span>
          </button>
      </>
    );
  };

同时我们希望通过css来控制全屏的样式,因此我们需要通过上述fullScreen来给予modal不同的样式名。

const { fullScreen } = this.state;
render() {
  <Modal
                wrapClassName={`${fullScreen ? 'modal-wrap-fullscreen' : ''}`}
                title={this.titleRender()}
                {...rest}
 />
}

上述代码我们通过modal-wrap-fullscreen来控制全屏的时候的样式,这边需要css控制的样式主要有:

  • 控制modal高度为浏览器可视区域高度,这边可以通过100vh来实现,宽度为100%即可
  • 控制modalbody高度为浏览器可视区域高度 - 头部区域高度 - 底部区域高度。这边如果需要实现无底部区域等情况,还可以继续细分赋予Modal不同的wrapClassName来控制
  • 可以将边角由圆角改成直角

其它控制参数

  • 默认全屏功能
    要实现默认全屏功能,那么用户得传入一个参数表明默认全屏。此处我们同样在props增加一个参数名为fullScreen的参数,并且state中的初始值由props中的参数决定即可。
  • 隐藏控制图标
    同样我们增加一个名为maxmin的属性来控制
titleRender = () => {
  const { title, maxmin } = this.props;
  const { fullScreen } = this.state;
  return (
      <>
        {title}
        {maxmin && (
          <button
            type="button"
            className="ant-modal-close"
            style={{ right: 42 }}
            onClick={this.toggleFullScreen}
          >
            <span className="ant-modal-close-x">
              <Icon className="ant-modal-close-icon" type={fullScreen ? 'shrink' : 'arrows-alt'} />
            </span>
          </button>
        )}
      </>
    );
  };

结语

上述代码只是为了说明实现思路作为参考,可能并不完整。详细可以查看我托管的代码,当然我封装的代码中实现的功能会更多一点,具体可以看这

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容