دسته بندی ها
14:58 1401/08/10

آپلود فایل درون حلقه for در Asp.net core

مشخصات سوال کننده :
کاربر : frisat     امتیاز کاربر : ‎−2     رتبه کاربر : 7132
دسته بندی : Asp.net Core جاوا اسکریپت

به این سوال امتیاز بدهید    ‎−1
تعداد بازدید این سوال : 1778
2 نظر
saedbfd : دوست عزیز لطفا کدهایی که قرار می دید رو خلاصه کنید. فقط کدهایی که نیاز هست رو قرار بدید. الان شما مقدار زیادی کد قرار دادید که اصلا مشخص نیست کجا رو باید بررسی کنیم. کدهای اضافه رو پاک کنید و سوال رو خلاصه تر و قابل فهم تر کنید. تشکر

امتیاز کاربر : 1664   رتبه کاربر : 1   تاریخ ثبت : 00:04 1401/08/11
frisat : ویرایش انجام شد لطفا پاسخ بدبد

امتیاز کاربر : ‎−2   رتبه کاربر : 7132   تاریخ ثبت : 01:40 1401/08/11
هوش مصنوعی

پاسخ هوش مصنوعی

برای حل مشکل آپلود فایل درون حلقه `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>
به این پاسخ امتیاز بدهید    0
امتیاز: - رتبه: -
پاسخ دهنده : mrx10 02:52 1401/08/16

با سلام

معمولا برای ایجاد فرم از حلقه استفاده نمی کنیم، مگر برای جداول.
اگر حتما قصد دارید از حلقه استفاده کنید پیشنهاد من اینه که به هر کدوم از اینپوت ها یه عدد (با کمک از شمارنده حلقه) به آخر همه ID ها اضافه کنید که بتونید به هر اینپوت با ID خودش بهش دسترسی داشته باشید.
همچنین از این روش از name هم استفاده کنید خالی از لطف نیست.

به این پاسخ امتیاز بدهید    0
امتیاز: 0 رتبه: 7070
برای ارسال پاسخ لطفا وارد حساب کاربری خود شوید.   ورود