NG-ZORRO 使用相关
Upload上传
import { Component, Input, Output, EventEmitter, Inject } from '@angular/core';
import { NzMessageService, UploadFile, UploadFilter, UploadXHRArgs } from 'ng-zorro-antd';
import {
HttpRequest,
HttpClient,
HttpEventType,
HttpEvent,
HttpResponse
} from '@angular/common/http';
import { forkJoin } from 'rxjs';
import { HttpService } from './httpService';
export class File {
uid: '';
name: '';
status: 'done';
url: '';
}
export class UploadFileType {
'fileId': '';
'fileName': '';
'fileSize': '';
'fileUrl': '';
'sequence': '0';
} @Component({
selector: 'UploadPictureCardComponent',
template: `
<nz-upload
[nzAction]='urlConfig.url+"文件上传地址后缀"'
(nzChange)="handleChange($event)"
nzListType="picture-card"
[nzBeforeUpload]="beforeUpload"
[nzFilter]="filters"
[nzShowUploadList]="false"
[(nzFileList)]="fileList">
<i class="anticon anticon-plus"></i>
<div *ngIf='!childIsLoad' class="ant-upload-text">Upload</div>
<div *ngIf='childIsLoad' class="ant-upload-text">文件上传中{{progress}}...</div>
</nz-upload>
`
})
export class UploadPictureCardComponent {
fileList: File[] = [];
uploadFiles: UploadFileType[] = [];
previewImage = '';
previewVisible = false;
progress = ''; //上传进度
@Input() childIsLoad;
@Input() flieSessionStoragesName; //文件存在sessionStorage中的键值
@Output() private childOuter = new EventEmitter(); //子组件向父组件传值
@Output() private childIsLoadOuter = new EventEmitter(); //告诉父组件是否上传中
constructor(
private msg: NzMessageService,
private httpService: HttpService,
@Inject('urlConfig') public urlConfig
) {}
ngOnInit() {
//初始化文件
} //上传限制
filters: UploadFilter[] = [
{
name: 'type',
fn: (fileList: UploadFile[]) => {
const filterFiles = fileList.filter(
w =>
~['image/png', 'image/jpg', 'image/gif', 'image/bmp', 'image/jpeg'].indexOf(
w.type
)
);
if (filterFiles.length !== fileList.length) {
this.msg.create('error', '请上传png、jpg、gif、bmp、jpeg格式的图片!');
return filterFiles;
}
return fileList;
}
}
];
//上传之前的操作
beforeUpload = (file: File) => {
let ispass = true; //是否继续往下执行
console.log('上传之前的操作');
//以下操作在
if (window.sessionStorage.getItem(this.flieSessionStoragesName)) {
let list_ = JSON.parse(window.sessionStorage.getItem(this.flieSessionStoragesName));
for (let i in list_) {
if (file.name == list_[i].fileName) {
ispass = false;
this.msg.create('warning', '请勿上传同名文件!');
break;
}
}
}
return ispass; //返回true继续执行,false直接停止
}; //开始、上传进度、完成、失败都会调用这个函数
handleChange(info: any): void {
console.log(info);
if (info.type == 'start') {
this.childIsLoadOuter.emit(true); //告诉父组件上传中
this.progress = '0%';
}
if (info.type == 'progress') {
this.progress = info.event.percent.toFixed(2) + '%';
}
if (info.type === 'success') {
this.progress = '';
console.log(info);
let file = new UploadFileType();
file.fileId = info.file.response['data'].id;
file.fileName = info.file.response['data'].name;
file.fileSize = info.file.response['data'].size;
file.fileUrl = info.file.response['data'].downloadUrl;
file.sequence = '0';
this.childOuter.emit(file); //向父组件传值
this.childIsLoadOuter.emit(false); //告诉父组件上传完成
this.msg.create('success', '上传成功!');
}
if (info.type === 'error') {
this.childIsLoadOuter.emit(false); //告诉父组件上传完成
}
}
}
NG-ZORRO 使用相关的更多相关文章
- Angular: 执行ng lint后如何快速修改错误
当我第一次被分配到“修正执行ng lint语句后的错误”这项任务前,我就被导师提前告知这是一个很无聊的任务,当我开始后,我发现其实有一些办法可以加快这个无聊单调的工作.接下来,我就分享一下我的经验. ...
- 记录项目版本升级angular4 ~ angular5
前言: 在上一篇ng4文章<angular4--实际项目搭建总结>中说过,等到ng5正式发布,并且蚂蚁的NG ZORRO兼容ng5之后,我会对ng4项目进行升级.这篇文章就是大概说下升级的 ...
- 如何用ABP框架快速完成项目(6) - 用ABP一个人快速完成项目(2) - 使用多个成熟控件框架
正如我在<office365的开发者训练营,免费,在微软广州举办>课程里面所讲的, 站在巨人的肩膀上的其中一项就是, 尽量使用别人成熟的框架. 其中也包括了控件框架 abp和52abp ...
- 52ABP模板 ASP.Net Core 与 Angular的开源实例项目
阅读文本大概需要 5 分钟. 开始之前 自从上一篇文章".NET:持续进化的统一开发平台"发布后,已经有三个月的时间没有写过文章了. 这段时间,做了两场线下活动,一场在上海,一场在 ...
- Angular2常用命令
一.常用命令 1.1 npm config list配置项目 可进行相关代理配置,通常可以配置在网络环境较差的情况下,配置相关代理.相关的设置命令如图: 1.2 ng 新建启动项目 ng new pr ...
- 2021 年最值得推荐的 7 个 Angular 前端组件库 - DevUI
摘要:DevUI 是一款面向企业中后台产品的开源前端解决方案,它倡导沉浸.灵活.至简的设计价值观,提倡设计者为真实的需求服务,为多数人的设计,拒绝哗众取宠.取悦眼球的设计.如果你正在开发 ToB 的工 ...
- 嵌入式单片机STM32应用技术(课本)
目录SAIU R20 1 6 第1页第1 章. 初识STM32..................................................................... ...
- Andrew Ng机器学习笔记+Weka相关算法实现(四)SVM和原始对偶问题
这篇博客主要解说了Ng的课第六.七个视频,涉及到的内容包含,函数间隔和几何间隔.最优间隔分类器 ( Optimal Margin Classifier).原始/对偶问题 ( Primal/Dual P ...
- Andrew Ng机器学习笔记+Weka相关算法实现(五)SVM最优间隔和核方法
这一章主要解说Ng的机器学习中SVM的兴许内容.主要包括最优间隔分类器求解.核方法. 最优间隔分类器的求解 利用以一篇讲过的的原始对偶问题求解的思路,我们能够将相似思路运用到SVM的求解上来. 详细的 ...
- 走进AngularJs(二) ng模板中常用指令的使用方式
通过使用模板,我们可以把model和controller中的数据组装起来呈现给浏览器,还可以通过数据绑定,实时更新视图,让我们的页面变成动态的.ng的模板真是让我爱不释手.学习ng道路还很漫长,从模板 ...
随机推荐
- Less(4)
1.先判断注入类型 (1)首先看到要求,要求传一个ID参数,并且要求是数字型的:?id=1 (2)再输入?id=1' 界面无变化 (3)再输入?id=1'' 界面还是无变化, (4)再输入?id=1 ...
- day87_11_7微信小程序之登录,支付(获取ip,requests使用),授权
一.登录接口. 官方文档https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/login.html 在登录接口 ...
- centos7删除MariaDB怎么操作
有时我们要在centos上安装一些组件,需要先把原来的数据库删除,比如MariaDB,不然就出现冲突错误,那么如何删除数据库呢?首先查询所安装的MariaDB组件: [root@localhost l ...
- LG1131 「ZJOI2007」时态同步 树形DP
问题描述 LG1131 题解 正难则反,把从一个点出发到叶子结点看做从叶子结点走到那个点. DP方程很显然. \(\mathrm{Code}\) #include<bits/stdc++.h&g ...
- <Design> 359 346
359. Logger Rate Limiter 用map搭建. class Logger { HashMap<String, Integer> map; /** Initialize y ...
- pyEcharts安装及使用指南(最新)
pyEcharts安装及使用指南(最新): 网上资料大多数是0.5X的版本, 这里我给出我的0.5版本连接https://www.cnblogs.com/dgwblog/p/11811562.html ...
- 使用csv模块读写csv格式文件
import csv class HandleCsv: ''' csv文件处理类 ''' def __init__(self, filename): ''' 构造器 :param filename: ...
- C# windows服务,解决应用程序开机自启问题
最近在东营做一个超市购物的项目,业务体量很小,是仅供内部员工使用的内网应用程序,其中涉及一个商品数据同步的winform应用程序,有一个问题就是服务器重启后,必须登录服务器操作系统,手动启动才行,于是 ...
- MySQL(10)---自定义函数
MySQL(10)---自定义函数 之前讲过存储过程,存储过程和自定义函数还是非常相似的,其它的可以认为和存储过程是一样的,比如含义,优点都可以按存储过程的优点来理解. 存储过程相关博客: 1.MyS ...
- 使用C#+Edge (Chromium)进行Web自动化测试
今天看到了VisualStudio中现在已经自带了Web单元测试项目模板,便试了一下,发现还比较好用,它默认的是Selenium实现的,测试组在用Selenium+Python来写过自动化测试,原来它 ...