美文网首页
B端产品小功能设计1:批量导入

B端产品小功能设计1:批量导入

作者: 涛涛记得笑 | 来源:发表于2020-06-30 09:04 被阅读0次

    今天分享一个B端产品设计中经常或者说必须用到的功能:批量导入。

    相信很多小伙伴都对这个功能有接触和了解,觉得不过就是个简单的把Excel表的数据导入到系统而已。

    道理是这么个道理,但小功能也有它的奥妙之处,况且批量导入是个很不一般的非常重要的功能,特别在B端产品设计中。

    一个做得好的批量导入功能,可以大大提高使用者的工作效率。

    那么我们在设计这个功能时,需要考虑什么呢?我罗列了几点:

    如何才能让用户在批量导入过程中尽可能地减少出错的概率。

    若真的出现导入错误应该怎么处理,如何提示用户修改,用什么方式更好。

    批量导入的数据量大概有多大。

    导入的数据,如果与原有数据冲突时,该怎么处理。

    一、设计批量导入的模板

    众所周知,在做导入功能时,我们都会用到Excel表。由于用户在Excel中的输入编写是很自由的,如果不把Excel定好格式模板,告诉用户我们的填写规则,那么用户填写完的信息导入系统时,很大概率是不符合规范的,所以第一步必须要定好Excel的模板。

    首先,要在Excel中把填写规则表述清楚。

    例如这个报表的填写功能的批量导入的说明,我们可根据各自的业务规则需求,制定适合自己的规则。

    而且,在一些需要与系统数据库进行匹配校验的数据,要控制好输入格式,可以让用户选择,就不要让用户编辑输入。

    例如:省市区这类型,例如广东省,如果用户输入,很可能有的用户输入“广东”,这样在和数据库进行匹配或者校验时就会匹配不到数据。所以我们要尽可能避免这种情况。

    二、使用步骤引导用户

    尽可能把入口放在易见的位置,例如列表页top。在用户首次进行导入操作时,肯定是需要先下载一个模板的,所以我们可以在按钮旁边加一个说明指引:“第一步:下载模板;第二步,编写内容,批量导入。”

    三、提示用户现在的状态,如何进行下一步

    用户按照模板填写完后,就可以点击【批量导入】按钮把数据导入。

    此时,我们需要两种情况:数据正确无误成功导入;导入的数据存在错误。

    导入数据后,先校验数据是否有错误,如果正确无误,那么就可以直接在数据库创建数据,也可以把数据先进行页面化显示,让用户对数据进行再次确认再进行手动提交入库。

    在这里,我们是建议使用先页面化显示这种方式,一是可以让用户知道自己导入了哪些数据,二是当有错误的时候,可在页面中直观的让用户看到哪几行出了错(当然这种方式要考虑数据量的问题,如果数据量非常大就不适用这种方式)。

    而对于导入后某些数据有错的情况,我们一般又可以分为两种方式进行处理:

    1.允许用户在线直接修改,导入后提示用户有几条错误,可以在线进行编辑修改,修改后进行保存。

    进行调整也有两种调整方式:直接在列表中实现可编辑的;点击列表,弹窗页进行编辑。

    一般都更推荐第二种方式,实现起来更灵活,可直接使用前端的组件

    2.不允许用户在线修改,需要重新上传。我们需要提示用户Excel中,哪几行的数据错误,错误原因是什么?

    至于用哪种方式,一般根据实际情况考虑,特别是数据量,如果错误的数据量大还是建议不允许用户在线修改,提供一个让用户自己下载“错误报告”的功能(用户上传的Excel附加一个错误说明),让用户对着错误说明在Excel上进行修改,重新上传(毕竟在Excel中批量修改会比在线修改效率要高很多)。

    四、如何处理有冲突的数据

    在最后,还有一个需要考虑的问题,就是导入的数据存在冲突时该如何处理。我们这个导入是增量导入还是支持覆盖导入?

    如果是要支持如果要支持覆盖导入,那么这个导入列表就需要加一个在系统中的唯一标识。

    以通讯录为例,导入的列表要加一个员工编号,当导入的时候,检测这个员工编号在原来系统中是否存在,如果存在,那么就是对原来那条记录的修改,并且提示用户,是否对该记录进行修改,可展示前后对比给用户看。如果不存在,那么就是新增。

    还有一种情况是数据备案导入,那么就要保留原有的历史数据,同时存储新导入的数据。

    以上是在设计批量导入功能时需要考虑的几个点,基本可以满足各种常规的需求,如果还有更好的优化方法,记得给我提建议哦~

    相关文章

      网友评论

          本文标题:B端产品小功能设计1:批量导入

          本文链接:https://www.haomeiwen.com/subject/pmjtqktx.html