Angular 上传文件 可参考Angular2使用ng2-file-upload上传文件

这里记录在开发过程中遇到的问题:

  1. 删除选择的文件后,不能再选择上次选择的相同的文件

在 firefox 浏览器中,当未选择文件时,原样式是:



当已选择文件时,原样式是:

根据设计要求,需要添加删除按钮,用于删除选择的文件。

在开发的过程中发现删除后,不能选择上一次选择的相同的文件,而其他的文件可以选择。

因为选择文件的时候是用的 (change)事件,所以在删除之后不能选择相同的文件。

我的方法是,删除之后清除掉上传的 input dom,然后再创建这个 dom。

模板中:

input 元素添加 *ngIf = "isShowSelectFile"

组件中:

初始化时,isShowSelectFile: boolean = true;

删除时:

this.isShowSelectFile = false;
setTimeout(() => {
this.isShowSelectFile = true;
}, 100);

这里附上关键代码,查看codepen在线示例关键代码(**ng2-file-upload 插件在 Angular 中怎么使用请参考Angular2使用ng2-file-upload上传文件 **):

<div class="upload-template">
<strong>上传模板:</strong>
<div class="upload-file-container">
<span class="upload-name" [class.uploaded-template]="selectedFileName !== '选择文件'">{{selectedFileName}}</span>
<input id="selectFile" type="file" *ngIf="isShowSelectFile" placeholder="选择填写好的数据文件" title="选择填写好的数据文件"
ng2FileSelect
[uploader]="uploader"
[disabled]="isImportingData"
accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
(change)="selectedFileOnChanged($event)">
</div>
<!--若文件已上传-->
<button [hidden]="selectedFileName == '选择文件'" type="button" class="delete" title="删除" (click)="deleteUploadedFile()">删除</button>
</div>
// 删除上传的文件
deleteUploadedFile() {
this.selectedFileName = "选择文件";
this.uploader.clearQueue();
this.uploadEnabled = false;
this.isShowSelectFile = false;
setTimeout(() => {
this.isShowSelectFile = true;
}, 100);
} selectedFileOnChanged(event:any) {
let filePath = event.target.files[0].name; //用户取消选择文件
if(event.target.value =="") {
this.uploader.clearQueue();
this.selectedFileName = "选择文件";
this.uploadEnabled = false;
} else {
//每次选择后,都只保留最新选择的文件
let fileCount = this.uploader.queue.length;
if(fileCount > 1) {
for(let i = 1; i < fileCount; i++) {
this.uploader.removeFromQueue(this.uploader.queue[0])
}
}
} this.uploadEnabled = this.uploader.queue.length > 0;
}
SCSS:

.upload-template {
$size: 36px;
.upload-file-container {
position: relative;
height: $size;
line-height: $size;
cursor: pointer;
margin-left: 10px;
.upload-name {
z-index: 2;
width: 100%;
position: absolute;
top: 0;
bottom: 0;
right: 0;
left: 0;
display: block;
text-decoration: underline;
height: $size;
line-height: $size;
color: #29e;
overflow-x: hidden;
text-overflow: ellipsis;
white-space: nowrap;
&.uploaded-template {
color: #444;
text-decoration: none;
}
& + input {
z-index: 3;
width: 100%;
position: absolute;
top: 0;
bottom: 0;
right: 0;
left: 0;
display: block;
height: $size;
line-height: $size;
opacity: 0;
}
}
}
.delete {
float: left;
color: #f00;
line-height: $size;
padding-right: 1em;
padding-left: 1em;
}
}

在 firefox 浏览器中,当未选择文件时,美化后样式是:



当已选择文件时,美化后样式是:

Angular 使用 ng2-file-upload 上传文件遇到的问题的更多相关文章

  1. Struts Upload上传文件

    1.Unable to find 'struts.multipart.saveDir' property setting. Defaulting to javax.servlet.context.te ...

  2. php 下 html5 XHR2 + FormData + File API 上传文件

    FormData的作用: FormData对象可以帮助我们自动的打包表单数据,通过XMLHttpRequest的send()方法来提交表单.当然FormData也可以动态的append数据.FormD ...

  3. element-ui upload上传文件并携带参数 使用formData对象

    需求:上传文件的时候,需要携带其他的参数 问题:使用upload上传文件时,必须使用formData对象,而其他的参数通过data获取的到的,formData和data是不能同时传输的 解决:获取到的 ...

  4. thinkphp Upload上传文件在客户端生成的临时文件$_FILES['file']['tmp_name']

    1.关于thinkphp 的Upload的$_FILES['file']['tmp_name'] 在使用thinkphp上传图片的时候,在上传的$_FILES数组中,有一个$_FILES['file' ...

  5. input type file onchange上传文件的过程中,遇到同一个文件二次上传无效的问题。

    不要采用删除当前input[type=file]这个节点,然后再重新创建dom这种方案,这样是不合理的.解释如下:input[type=file]使用的是onchange去做,onchange监听的为 ...

  6. SSH Secure File Transfer上传文件错误:encountered 1 errors during the transfer解决办法

    在使用SSH 工具向Linux服务器上传文件时,弹出 encountered 1 errors during the transfer 错误. 解决方案: 1.准备上传的那个文件所在目录路径存在(), ...

  7. ie8及其以下版本兼容性问题之input file隐藏上传文件

    文件上传时,默认的file标签很难看,而且每个浏览器下都有很大差距.因此我们基本都把真正的file标签给隐藏,然后创建一个标签来替代它.但是由于IE出于安全方面的考虑上传文件时必须点击file的浏览按 ...

  8. input[type='file']获取上传文件路径案例

    最近在项目时,需要获取用户的上传文件的路径,便写了一个demo: <body> <input type="file" name="" valu ...

  9. input type file onchange上传文件的过程中,同一个文件二次上传无效的问题。

    不要采用删除当前input[type=file]这个节点,然后再重新创建dom这种方案,这样是不合理的.解释如下:input[type=file]使用的是onchange去做,onchange监听的为 ...

  10. input type='file'限制上传文件类型

    前端与后台数据进行对接时,就避免不了要使用ajax进行http请求,常用的请求就两个post与get:然而常见的post请求的需求是文件上传,可能我一说到文件上传大家都觉得so  easy啊,没什么嘛 ...

随机推荐

  1. EJS的个人总结

    什么是模板引擎? 用于Web开发的模板引擎是为了使用用户界面与业务数据(内容)分离而产生的,使用模板语法编写的模板代码通常放在具有特的格式的文档中,经过模板引擎编译之后就会生成一个标准的HTML文档. ...

  2. 论文画图工具使用(2)vision软件

    1 软件安装和破解 https://www.cnblogs.com/shitou6/p/8986396.html 自己的网盘 链接:https://pan.baidu.com/s/1EWU0xLMTI ...

  3. Python 10 训练模型

    原文:https://www.cnblogs.com/denny402/p/7520063.html 原文:https://www.jianshu.com/p/84f72791806f 原文:http ...

  4. 关于wineQQ8.9.19983deepin23版本提升不能在使用请升级,Linux偷懒升级方法

    安装wineQQ8.9.19983deepin23版本后提示,不在提供服务请升级. 第一步 前往QQ官方下载Windows最先版本QQ https://qd.myapp.com/myapp/qqtea ...

  5. nginx return配置说明

    该指令一般用于对请求的客户端直接返回响应状态码.在该作用域内return后面的所有nginx配置都是无效的. 可以使用在server.location以及if配置中. 除了支持跟状态码,还可以跟字符串 ...

  6. [已解决] Python logging 重复打印日志信息

    问题描述 问题代码如下: def get_logger(logger_name): """得到日志对象""" logger = loggin ...

  7. zabbix监控ESXI主机

    ESXI6.0默认SSH关闭的,打开SSH的方法如下图: SSH打开后,主机会有警报,关闭警报的方法如下图 esxcli system  snmp  set  --communities  publi ...

  8. ubuntu之路——day19.2 开源框架与迁移、CNN中的数据扩充

    开源框架与迁移 上面介绍了一些已经取得很好成绩的CNN框架,我们可以直接从GitHub上下载这些神经网络的结构和已经在ImageNet等数据集上训练好的权重超参数. 在应用于我们自己的数据时. 1.如 ...

  9. 解决vue视图不渲染

    动态添加对象属性 //声明var travelMainVueObj;travelMainVueObj = new Vue({ "el" : "#portletConten ...

  10. git修改提交作者和邮箱

    作用一名程序员,我们会经常混迹与不同的代码仓库,时常不同仓库会有作者信息验证.比如公司内建的gitlab一般会要求统一使用公司内部的域账号签名:github要求使用github账号签名等.因此,很容易 ...