ant design pro和quill.js在实际工作遇到的问题

1、ant design pro 网络请求封装中的坑

Ant design pro中的网络请求时封装了fetch来实现的,pro约定了当状态码200~300为网络请求成功状态,其余均为失败状态。其次,pro对delete方法以及网络状态为204时自动做了text()方法,在校验delete方法时,要注意json.parse()后进行校验,并且谨慎使用204的网络状态。


网络状态200·300成功


删除,204时toText处理

避免网络状态错误后,造成js报错。比如,接口token超时返回401时,这时不会返回response,要避免在直接对resopnse内深层数据的判断。


2、富文本中的坑(基于quill.js)

在引用富文本后,输出为html标签形式的文本,输出文本的样式方面,富文本采用的做法是:引入主题css样式,有class和style共同起作用,这就导致了将输出的文本直接插入dom容器中,样式与富文本内不一致的问题,解决方案为:在需要现在富文本内容的外层容器上,手动填加class类名,并且保证富文本文字在css的作用域内。

富文本字数的坑,富文本是dom元素形式,在判断文字长度上会出现问题,并不能准确无误的限制文字数量,可以用一些第三方的domToString工具大概计算出文体长度,但是不建议对富文本做字数限制。

定制富文本样式的坑:富文本组件的内容一般有两种形式,一种是通过before、after伪类通过css的方式渲染组件上的文字图案,这种可以通过覆盖css直接解决。另外一种是写在模板里的,这种方式的文案无法用常规方式修改,只能通过自定义富文本组件(自己实现),以及修改dom元素的方式。两种方式均不推荐。

富文本内置组件处理输入数据的坑:以链接组件为例,例如需要对链接的输入做校验,可以通过继承富文本组件类,重构create方法实现,create方法必须返回一个dom元素,所以,当输入不合法是,需要返回一个空dom元素。不可以不返回。


富文本弹出插件布局的坑:富文本弹出插件是以内部dom元素做的绝对定位,当富文本内部出现滚动时,富文本弹出插件的位置会错乱,解决方案是:让富文本随着文字增加,自动加长高度。

3、错误提示风格问题导致的坑

提示风格不统一最主要原因是,对于一些非常规表单元素,或者是大表单夹在着的非常规表单元素没有按照自定义表单元素来处理。在代码最开始写的时候,就使用自定义表单控件来构建。

https://ant.design/components/form-cn/#components-form-demo-customized-form-controls

4、字符串为空串的坑

在校验、提交前,执行trim()操作,但是要避免对null和undefined做trim,所以,需要做trim的字段如果有默认值(初始值)时,要给’’,而不是nulll和undefined。

5、按钮重复点击的问题

对于时间较长的操作,直接添加loading效果,对于时间较短且不可以多次点击的操作,添加debounce节流。

6、对于存在默认值并且可以修改的地方(用户头像)自动闪(改变)的问题

监听获取的网络请求,对返回值进行判断,没有显示默认,有显示网络数据,获取数据时,使用loading优化体验。

7、前端单页APP样式冲突

使用cssmodules,避免直接给元素写class类名,而是通过style.XXX引入,在直接对标签修改样式时,外层要包裹类名,避免污染全局。

8、前端单页APP路由参数改变不会重新走全部生命周期的坑

只有路由参数变化,进行路由push方法时,是不会走组件的生命周期中的方法,对于复用页面间直接跳转场景时,是不会刷新页面的。解决方案有两种,第一,修改路由地址,复用页面使用不同地址但是指向同一个组件。第二,使用dva中的subscriptions,监听路由去触发action。

9、前端单页APP数据缓存的问题

在项目开发后期有提到这个需求,但是改动风险大并未做实现,对这个需求,有一个设想的解决方案。保留页面离开时现场(redux默认已经实现,redux数据默认不会清空),在组件的初始时,判断路由参数中页面场景的变量,来决定是否走页面的初始化还是返回现场。

具体来说,把页面的数据分为两类存储在redux中,一类是决定因素的数据,表格分页,排序信息。另外一类是页面数据。当页面数据回滚时,直接显示页面数据,当页面需要初始化时,修改决定因素数据(第一部分),并获取到页面数据用于显示。当遇到保留决定因素(分页信息保留),但需要重新获取页面数据时,用决定数据去重新获取页面数据。

10、蚂蚁组件样式覆盖的坑

对于常规组件,只要控制好css作用域,在需要覆盖的class外嵌套一层global选择器即可,对于一些弹出类的组件,组件dom节点并不在当前的页面下(通常在body下),这是,需要给组件填在外层样式类名,并且在全局中添加这个外层样式类名,并在这个样式类名下使用global选择器修改默认样式。

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

推荐阅读更多精彩内容

  • # 传智播客vue 学习## 1. 什么是 Vue.js* Vue 开发手机 APP 需要借助于 Weex* Vu...
    再见天才阅读 3,536评论 0 6
  • 前言 您将在本文当中了解到,往网页中添加数据,从传统的dom操作过渡到数据层操作,实现同一个目标,两种不同的方式....
    itclanCoder阅读 25,792评论 1 12
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,472评论 1 45
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,748评论 1 92
  • 看看这篇文章,必让你觉得值得! 几件小事,让人思考每个人都该有个靠谱的医生能随时随地咨询!怕这种紧急情况发生! 事...
    何蓉阅读 417评论 0 0