آپلود فایل درون حلقه for در Asp.net core
سلام.من یک لیست دارم که برای هر رکورد از این لیست میخوام یک فایل با ایجکس آپلود کنم ولی چون درون حلقه for هستم و برای اینپوت آپلود فایل یک ID قرار دادم فقط فایل رکورد اولی آپلود میشود و بقیه رکوردها آپلود نمیکنند لطفا کد و تصویر رو چک کنید و راهنمایی بفرماید
@for (var i = 0; i < Model.Count(); i++)
{
<td>
<div class="d-flex justify-content-around">
<div>
<span class="text-center mt-2" id="spnImageCartMlie" style="color: black;font-size: 12px"></span>
</div>
<div>
<input type="button" required onclick="UploadImage()" value="Upload" class="btn btn-outline-danger " id="btnUpLoad" />
<div id="divmessage" class="text-center hidden m-2"></div>
</div>
<input id="mostanadPath" name="[@i].prosessMastand" type="file" class="">
</div>
</td>
}
<script>
var UploadImage = function () {
var data = new FormData;
var file = $("#mostanadPath").get(0);
for (var i = 0; i < files.length; i++) {
data.append('filearray', files[i]);
data.append('filesize', files[i].size);
}
data.append('path', "img\\mostandat\\");
$.ajax({
xhr: function () {
var xhr = new window.XMLHttpRequest();
xhr.upload.addEventListener("progress", function (evt) {
if (evt.lengthComputable) {
var percentComplete = evt.loaded / evt.total;
percentComplete = parseInt(percentComplete * 100);
$('.progress-bar').width(percentComplete + '%');
$('.progress-bar').html(percentComplete + '%');
}
}, false);
return xhr;
},
url: '@Url.Action("UploadImageFile", "Tax")',
type: "POST",
data: data,
contentType: false,
processData: false }).done(function (result) {
if (result.status == "success") {
toastr.success('فایل با موفقیت آپلود شد', {
timeOut: 2000,
closeButton: true,
});
$("#newCartMlieImagePathName").val(result.imagename);
}
</script>

پاسخ هوش مصنوعی
برای حل مشکل آپلود فایل درون حلقه `for`، باید از شناسه های یکتایی برای هر ورودی استفاده کنید. در حال حاضر، تمامی ورودی های فایل شما دارای شناسه یکسانی هستند، بنابراین هنگام انتخاب فایل تنها ورودی اول انتخاب می شود.
به جای استفاده از شناسه ثابت برای ورودی فایل و دکمه آپلود، می توانید از اندیس `i` در حلقه `for` استفاده کنید. بدین صورت هر قطعه خود را دارای شناسه یکتایی خواهید کرد.
در زیر کد اصلاح شده را مشاهده می کنید:
@for (var i = 0; i < Model.Count(); i++)
{
<td>
<div class="d-flex justify-content-around">
<div>
<span class="text-center mt-2" id="spnImageCartMlie" style="color: black;font-size: 12px"></span>
</div>
<div>
<input type="button" required onclick="UploadImage(@i)" value="Upload" class="btn btn-outline-danger" id="btnUpLoad_@i" />
<div id="divmessage_@i" class="text-center hidden m-2"></div>
</div>
<input id="mostanadPath_@i" name="[@i].prosessMastand" type="file" class="">
</div>
</td>
}
<script>
var UploadImage = function (index) {
var data = new FormData;
var file = $("#mostanadPath_" + index).get(0).files[0];
if (file) {
data.append('filearray', file);
data.append('filesize', file.size);
data.append('path', "img\\mostandat\\");
$.ajax({
xhr: function () {
var xhr = new window.XMLHttpRequest();
xhr.upload.addEventListener("progress", function (evt) {
if (evt.lengthComputable) {
var percentComplete = evt.loaded / evt.total;
percentComplete = parseInt(percentComplete * 100);
$('.progress-bar').width(percentComplete + '%');
$('.progress-bar').html(percentComplete + '%');
}
}, false);
return xhr;
},
url: '@Url.Action("UploadImageFile", "Tax")',
type: "POST",
data: data,
contentType: false,
processData: false
}).done(function (result) {
if (result.status == "success") {
toastr.success('فایل با موفقیت آپلود شد', {
timeOut: 2000,
closeButton: true,
});
$("#newCartMlieImagePathName").val(result.imagename);
}
});
} else {
alert("لطفا یک فایل انتخاب کنید.");
}
};
</script>
با سلام
معمولا برای ایجاد فرم از حلقه استفاده نمی کنیم، مگر برای جداول.
اگر حتما قصد دارید از حلقه استفاده کنید پیشنهاد من اینه که به هر کدوم از اینپوت ها یه عدد (با کمک از شمارنده حلقه) به آخر همه ID ها اضافه کنید که بتونید به هر اینپوت با ID خودش بهش دسترسی داشته باشید.
همچنین از این روش از name هم استفاده کنید خالی از لطف نیست.
- جلوگیری از اد شدن خودکار در گروه و کانال تلگرام
- کم کردن حجم فیلم توسط کد در Asp net core
- چه کسانی استوری تلگرام را می بینند ؟
- برای کسب و کار تلگرام پرمیوم بهتره یا واتس اپ بیزینس ؟
- جلوگیری از انتشار غیرمجاز مطالب در کانال های تلگرامی
- تفاوت های تلگرام و واتس اپ چیست ؟
- چرا استوری های واتس اپ برای دوستان نمایش داده نمیشن ؟
- چند تا استوری رایگان می تونیم تلگرام بذاریم ؟
- خطای Severity Code Description Project هنگام استارت پروژه
- کار نکردن navBar و sideBar در پروژه Asp.net core
- کار با CkEditor با قابلیت آپلود عکس
- خطا در ایجاد migration در Asp.net core
- تفاوت های Asp.net core و Asp.net mvc چیه؟
- دلیل اسپم شدن ایمیل های ارسالی از سرور
- نحوه لایه بندی پروژه Core و اضافه کردن به IIS
- ارسال ایمیل در Asp.net core
- آیا میشه در mvc core از کامپونت استفاده کرد
- آپلود فایل در Asp.net core چگونه است؟
- حذف کامل یک رکورد در جدول ریلیشن شده
- اشکال در آپلود فایل ویدیو در mvc core 2