AngularJs 上传文件到服务器

本文介绍了如何在AngularJs项目中利用ng-file-upload插件进行文件上传。首先从GitHub下载该插件,并在项目中引入。接着展示了一个`ngf-select`指令的示例,用于选择文件并调用`uploadAPFiles`方法。此方法包含错误处理和文件上传逻辑,使用Upload.upload发送文件到指定URL。在上传过程中,可以显示进度信息,并在成功或失败时提供反馈。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

   现在项目中需要运用到AngularJs,其中用到AngularJs中上传文件功能,借此,记录下,怎样运用AngularJs中的组件。首先,去下载一个叫ng-file-upload的插件。下载地址:https://github.com/danialfarid/ng-file-upload  上面也关于怎样运用这个插件的。该插件需要自己在项目中定义到具体路径

define([

'angular',
'angular-route',
'angular-resource',
'angular-animate',
'angular-growl',
'angular-ngupload',
'controllers/index',
'directives/index',
'filters/index',

'services/index'

然后,代码中<button type="file"
ngf-select="uploadAPFiles($file, $invalidFiles)"
ngf-max-height="1000" ngf-max-size="150MB" ngf-pattern="'.bin'">
选择程序包并上传</button> 

上面代码中,主要是AngularJs中基础运用,通过uploadAPFiles方法,该方法在js文件中定义。

说说几个参数的意思,ngf-max-size表示限制上传的大小,ngf-pattern表示允许上传哪些文件,限制作用。JS文件中定义的方法,具体实现上传代码。下面:

$scope.uploadAPFiles = function(file,
errFiles) {


$scope.errFile = errFiles
&& errFiles[0];
if ($scope.errFile != undefined) {


BootstrapDialog
.show({
title : '通知消息',
message : '请选择合法的文件类型!'
});


}
if (file) {
file.upload = Upload.upload({
url : upload_url,
data : {
file : file
}
});


file.upload
.then(
function(
response) {
console
.log('Success '
+ response.config.data.file.name
+ 'uploaded. Response: '
+ response.data);
BootstrapDialog
.show({
title : '通知消息',
message : '上传AP程序成功'
});
$timeout(function() {
file.result = response.data;
});
},
function(
response) {
if (response.status > 0)
$scope.errorMsg = response.status
+ ': '
+ response.data;
},
function(evt) {
file.progress = Math
.min(
100,
parseInt(100.0
* evt.loaded
/ evt.total));
if (file.progress == 100) {


}
});
}
}

通过上面配置,填写好接口实现,就将文件上传到服务中,可以具体实现正在上传的文件的百分比,这个根据自己的需要去修改就可以了。谢谢!(有问题的地方可以大家交流,qq:1149748612)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值