【Axure教程】上传列表(本地文件结合中继器)

简介: 【Axure教程】上传列表(本地文件结合中继器)

上传列表可以说是系统必备的页面,我们可以将对应的文件上传到系统,上传的状态包括正在上传、上传成功、上传失败的状态都可以在上传列表中查看和处理。

所以本期教程主要介绍如何通过中继器做一个高保真的上传列表,让我们可以在Axure的演示界面做出上传本地文件的高保真效果。


一、制作完成后应具备以下效果

  1. 可以真实选择电脑里的本地文件;
  2. 选择本地文件后,获取已选中文件的名称信息;
  3. 模拟正在上传的等待效果;
  4. 可以删除已上传的文件;
  5. 上传失败后,点击上传失败文字,可以重新上传。

640.gif

二、制作材料准备

1. 中继器内材料

这个原型主要用中继器制作,所以我们需要新建一个中继器,中继器内材料包括:

  • 文件图片——文件图标;
  • 蓝色矩形——用于制作等待效果的横条,圆角设置为最大值;
  • 浅蓝色矩形——用于loading效果的背景横条,圆角设置为最大值;
  • 文件名称——显示文件名,用文本标签制作即可;
  • 上传状态——默认蓝色文字,默认内容为正在上传;
  • 删除按钮——删除当前文件的图标按钮;
  • 背景矩形——白色矩形,外部阴影为浅蓝色;
  • 垂直线——用于分隔和美化原型。

如下所示摆放:

640.png


中继器表格设置,表格内共三列:

  1. no——用于排序使用,按12345678顺序填写即可;
  2. text——对应文本名称的文本;
  3. state——上传状态包括上传成功、上传失败和正在上传。

640.png


2. 上传按钮组合

因为要实现本地上传文件、记录文件路径、获取文件名称、中继器添加行的效果,所以上传按钮不仅仅是一个按钮,它由以下4个部分组合。

1)蓝色按钮——命名为upload,至于顶层,在按钮组里只看到该元件,样式可以设置美观。

2)输入框——命名为file,这里我们需要利用Axure里面输入框的系统元件输入框,将输入框的输入类型设置为文本,这样鼠标点击输入框的时候,就可以弹出文件的系统弹窗了。我们把这个输入框缩小,用蓝色按钮遮挡。

640.png

3)文本标签——命名为text,用于记录选择文件的路径,默认隐藏,可直接用蓝色按钮遮挡。

4)文本标签——命名为click,用于上传文件后触发中继器添加行事件。


三、交互设置

1. 中继器载入时交互

添加排序——对中继器按钮no列的内容按升序的方式排列。这样做是为了后续添加新文件的时候,新文件可以排在首行的位置。

640.png


2. 中继器每项加载时交互

设置文本——设置文件名称元件的文本值等于Item.text,即中继器内text列的值。

640.png


然后我们需要分三种状态来设置,不同交互。


1)如果state列的值为正在上传

设置文本——设置上传状态元件的文本值等于Item.text,即中继器内text列的值,这里我们用富文本的形式,这样就可以选择设置文本的颜色为蓝色。

设置尺寸——设置蓝色矩形(上传横条)的尺寸,高于它原来的高度,宽等于1。因为是正在上传,所以将蓝色横条设置为最小准备制作loading的效果。

设置尺寸——再次设置蓝色矩形(loading横条)的尺寸,高于它原来的高度,宽等于灰色矩形(背景横条)的宽度,这里注意我们需要加一个动画时间案例中为2000ms,这样就实现了上传loading的效果。

等待——这里我们需要等待上面蓝色矩形动画时间结束,一般等待比它的时间稍长一点,案例中我们设置等待2500ms。

更新行——更新当前行state列的文字,更新为上传成功。

640.png

这样就顺利完成上传loading的效果了。


2)如果state列的值为上传成功

设置文本——设置上传状态元件的文本值等于Item.text,即中继器内text列的值,这里我们用富文本的形式,这样就可以选择设置文本的颜色为绿色。

设置尺寸——设置蓝色矩形(loading横条)的尺寸,高于它原来的高度,宽等于灰色矩形(背景横条)的宽度,这里注意不需要加动画时间,因为动画在正在上传的时候已经完成了,这里主要是默认的列表需要这样设置。

640.png


3)如果state列的值为上传失败

设置文本——设置上传状态元件的文本值等于Item.text,即中继器内text列的值,这里我们用富文本的形式,这样就可以选择设置文本的颜色为红色。

640.png


3. 上传状态文字鼠标单击时

上传状态分为上传成功、正在上传和上传失败,前两者不需要处理,如果上传失败,我们想实现点击文字就重新上传的效果。

更新行——更新当前行,state列的值,更新为正在上传。因为前面我们在中继器每项加载时写了正在上传的事件,所以更新行之后就会实现重新上传的效果。

640.png


4. 关闭按钮鼠标点击时

删除行——删除当前行的文件。


5. upload按钮鼠标单击时事件

这部分内容涉及一些js的代码,如果没有相关基础的话,可能理解起来会有一定的难度,下面我简单讲解一下思路。

首先是鼠标单击这个按钮的时候,我们click的代码触发file元件点击,这样相当于我们在点击蓝色上传按钮的时候,同时点击了file的元件,这样就可以弹出本地文件选择的弹窗。

640.png



选择本地文件后,我们要执行两端的代码:

  1. 将选择的文件路径名设置到text的元件里;
  2. 再次用click的代码,触发原型里click文本标签点击的事件。

后续我们会在click文本标签内添加交互,将已选择的文件名添加到中继器内。


6. click元件鼠标单击时事件

上面说到选择文件后会触发该元件鼠标单击时,那在鼠标单击时我们要执行一下交互。

1)标记行——标记所有行。

2)更新行——更新已标记的行,即更新所有行,更新no列,将他们的值改为

TargetItem.no+1。


这里的意思是将他们的no序号改成他们原来的值+1,这样原来是12345678的,就会变成23456789。这样做的目的就是后续我们新增行的时候,可以将最新的一行的no设为1,因为前面我们在中继器载入时设置了排序按照no的升序,所以新上传的文件就能排在第一行的位置。


3)添加行——更新no列的值为1,state列的值为正在上传,text列的值为LVAR1.slice((LVAR1.lastIndexOf(‘\\’))+1。


这里需要展开说明一下,因为我们选择文件以后,在text元件上获取到的是文件的路径,例如:C:\fakepath\微信截图_20211014105011.png,所以我们还要对text元件进行加工,LVAR1对应的就是text元件。


通过观察,我们可以发现,文件问就是最后一个\符号后面的内容,所以我们可以用lastIndexOf函数找到最后一个\符号所在的位置,然后用slice从该位置+1起到最后的文本,这样就取出了文件名称。

640.png


这样我们就完成了整个元件了,将它组合在一起,以后就可以直接复制或者从元件库用拖出来使用了,是不是非常好用呢?

那以上就是高保真上传列表的制作方法了,感兴趣的同学们可以动手试试,谢谢您的阅读。
作者:梓贤vigo;

微信公众号:Axure高保真原型,分享一系列产品经理常用的原型模板、教程、视频、文档等原创内容

本文由微信公众号:Axure高保真原型 授权发布,未经许可,禁止转载

相关文章
|
3月前
|
API
【sgUpload】自定义组件:自定义上传组件,支持上传文件夹及其子文件夹文件、批量上传,批量上传会有右下角上传托盘出现,支持本地上传图片转换为Base64image。
【sgUpload】自定义组件:自定义上传组件,支持上传文件夹及其子文件夹文件、批量上传,批量上传会有右下角上传托盘出现,支持本地上传图片转换为Base64image。
|
存储 PHP 数据安全/隐私保护
Ueditor结合七牛云存储上传图片、附件和图片在线管理的实现和最新更新
最新下载地址: https://github.com/widuu/qiniu_ueditor_1.4.3 Ueditor七牛云存储版本 注意事项 老版本请查看 : https://github.com/widuu/qiniu_ueditor_1.
3080 0
|
3月前
|
前端开发
表单设计器附件的上传、显示和下载
表单设计器附件的上传、显示和下载
36 1
表单设计器附件的上传、显示和下载
|
3月前
|
存储
Obsidian 与 Typora 图片兼容保存路径一致设置
Obsidian 与 Typora 图片兼容保存路径一致设置
291 0
|
3月前
|
存储 程序员
Typora设置 “图片自动保存到文档对应目录下” 的方法(亲测有效)
Typora设置 “图片自动保存到文档对应目录下” 的方法(亲测有效)
|
3月前
|
API
【sgUpload_v2】自定义组件:升级自定义上传组件,支持拖拽上传、弹窗上传单个或多个文件/文件夹,并且获取文件夹结构路径树,然后在右下角出现上传托盘。
【sgUpload_v2】自定义组件:升级自定义上传组件,支持拖拽上传、弹窗上传单个或多个文件/文件夹,并且获取文件夹结构路径树,然后在右下角出现上传托盘。
|
前端开发
织梦dedecms评论助手插件(支持图片视频上传与随机头像功能)
织梦评论助手是一款评论插件,安装后可以替代原有的织梦评论,立即拥有一个属于你自己网站的友好的评论系统。支持评论图片视频上传与评论者随机头像功能。
|
JavaScript
【Axure教程】上传列表(本地文件结合中继器)
【Axure教程】上传列表(本地文件结合中继器)
【Axure教程】上传列表(本地文件结合中继器)
|
JavaScript 前端开发
【Axure教程】上传本地图片
【Axure教程】上传本地图片
【Axure教程】上传本地图片