asp.net-mvc-4 – AngularJs,DropZone.Js,MVC4 – 拖放,预览和预览上传的图像
发布时间:2020-09-05 17:56:21 所属栏目:asp.Net 来源:互联网
导读:HTML: script src=~/Scripts/jquery-1.9.1.js/scriptscript src=~/Scripts/DropZone-2.0.1.js/scriptscript src=~/Scripts/angular.js/scriptscript src=~/App_Angular/app.js/script
|
HTML: <script src="~/Scripts/jquery-1.9.1.js"></script> <script src="~/Scripts/DropZone-2.0.1.js"></script> <script src="~/Scripts/angular.js"></script> <script src="~/App_Angular/app.js"></script> <div ng-app ="myApp" ng-controller ="ProductsCtrl"> <input ng-model="product.Name"/> <input ng-model="product.PhotoName" id="result" /> <form id="dropzone" class="fade well">Drop files here</form> <input type="button" value="Upload Files" ng-click="save(product)" /> 使用Javascript: $("#dropzone").dropzone({
url: 'Home/UploadFiles',paramName: "files",// The name that will be used to transfer the file
maxFilesize: 102,// MB
enqueueForUpload: false,accept: function (file,done) {
angular.element(document.getElementById('result')).scope()
.$apply(function (scope) {
scope.product.PhotoName = $('#result').val();
});
return done();
}
});
function uploadClicked() {
var dz = Dropzone.forElement("#dropzone");
for (var i = 0; i < dz.files.length; i++) {
dz.filesQueue.push(dz.files[i]);
}
dz.processQueue(dz);
$('#innerQue').empty();
}
在ng-click中调用save方法时,我已成功将照片名称传递给$scope.product.PhotoName. 我无法上传图片.我不知道如何从角度调用’uploadClicked’. 任何援助将不胜感激. 解决方法解决了(在Mark Rajcok的帮助下).完整解决方案 HTML: <script src="~/Scripts/jquery-1.9.1.js"></script> <script src="~/Scripts/DropZone-2.0.1.js"></script> <script src="~/Scripts/angular.js"></script> <script src="~/App_Angular/app.js"></script> <div ng-app ="myApp" ng-controller ="ProductsCtrl"> <input ng-model="product.Name"/> <input ng-model="product.PhotoName" id="result" /> <form id="dropzone" class="fade well">Drop files here</form> <input type="button" value="Upload Files" ng-click="save(product)" /> </div> 使用Javascript: $("#dropzone").dropzone({
url: 'Home/UploadFiles',done) {
angular.element(document.getElementById('result')).scope()
.$apply(function (scope) {
scope.product.PhotoName = $('#result').val();
});
return done();
}
});
function uploadClicked() {
var dz = Dropzone.forElement("#dropzone");
for (var i = 0; i < dz.files.length; i++) {
dz.filesQueue.push(dz.files[i]);
}
dz.processQueue(dz);
$('#innerQue').empty();
}
在这里修改dropzone.js: addedfile: function (file) {
file.previewTemplate = createElement(this.options.previewTemplate);
this.previewsContainer.appendChild(file.previewTemplate);
rem out --> //file.previewTemplate.querySelector(".filename span").textContent = file.name;
add this --> return ($('input[id=result]').val(file.name));
AngularController: function ProductsCtrl($scope,$routeParams,$http,$location) {
$scope.products = [];
$scope.product = {};
$scope.save = function (data) {
$scope.product = angular.copy(data);
$http.post('/api/Products',$scope.product)
.success(function () {
window.uploadClicked(); <---------------------- Solution
})
.error(function (data) {
// alert(data);
});
};
向MVC开发者增加奖励: public ActionResult UploadFiles(IEnumerable<HttpPostedFileBase> files)
{
//Works in Everything and IE10+**
if (!string.IsNullOrEmpty(Request.Headers["X-File-Name"]))
{
string path = Server.MapPath(string.Format("~/Uploads/{0}",Request.Headers["X-File-Name"]));
Stream inputStream = Request.InputStream;
FileStream fileStream = new FileStream(path,FileMode.OpenOrCreate);
inputStream.CopyTo(fileStream);
fileStream.Close();
}
} (编辑:哈尔滨站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- 如何将数组从Asp.net服务器端传递到客户端的Javascript函数
- asp.net html控件的File控件实现多文件上传实例分享
- linq – ASP.NET Web API GET方法:为单个参数传递多个值
- asp.net-mvc – 如何在我自己的自定义助手中使用ASP.NET MV
- asp-classic – 哪里可以存储经典ASP的连接字符串?
- asp.net-core – 如何在Visual Studio 2015 RC中为ASP.NET
- kendo-ui – 剑道网格刷新(数据绑定两次)
- asp.net fileupload控件上传文件与多文件上传
- asp.net – ASP MVC – 默认的HTTP标头有任何常量吗?
- asp.net实现access数据库分页的方法
