دریافت مقدار Viewbag توسط آرایه در جی کویری
سلام. توی پروژه خودم که با Asp.net core هست لیستی از مقادیر رو دارم که از سمت کنترلر به سمت View ارسال می کنم. هدفم این هست که این لیست رو توسط جی کویری دریافت کنم و درون یک آرایه بریزم تا بتونم از مقادیر اون آرایه استفاده کنم.
کدهایی که دارم در سمت کنترلر به شکل زیر هستند
   [HttpGet]
   public IActionResult Interview()
        {
            ViewBag.allQuestionAndList = _context.question.ToList();
            return View();
        }
همچنین در سمت کلاینت هم دستورات جی کوری رو به صورت زیر نوشتم
<script>
    $(document).ready(function () {
            var array = @Html.Raw(Json.Encode(@ViewBag.allQuestionAndList));
            alert(array);
        });
</script>
دستور بالا رو از اینترنت پیدا کردم توی این لینک ولی ظاهرا کمی خطا داره و Encode رو نمیشناسه.
حالا سوالم اینه چجوری میتونم مقدار ViewBag رو توسط دستورات جی کویری بریزم داخل یک آرایه و از اون استفاده کنم؟
پاسخ هوش مصنوعی
برای دریافت مقدار از ViewBag در سمت کلاینت و تبدیل آن به یک آرایه در جی کویری، می توانید از کد زیر استفاده کنید. ابتدا مطمین شوید که شما using Newtonsoft.Json; را به فایل کنترلر خود اضافه کرده اید که می تواند JsonConvert.SerializeObject را برای تبدیل لیست به JSON استفاده کند.
در کنترلر:
   [HttpGet]
   public IActionResult Interview()
   {
       var questionList = _context.question.ToList();
       ViewBag.allQuestionAndList = JsonConvert.SerializeObject(questionList);
       return View();
   }سپس در سمت کلاینت، می توانید از کد زیر استفاده کنید:
<script>
    $(document).ready(function () {
        var array = @Html.Raw(ViewBag.allQuestionAndList);
        alert(array);
    });
</script>این روش باید مشکل را حل کند و مقادیر ViewBag را به یک آرایه در جی کویری تبدیل کند. در صورتی که هنوز با خطا مواجه شدید، لطفاً نوع داده هایی که در ViewBag قرار می دهید را بررسی کنید.
گاهی اوقات لازم هست مقدار یک List رو از سمت کنترلر به View ارسال کنیم و توسط کدهای جی کوئری مقدار List ارسال شده رو دریافت کنیم و درون یک آرایه نگهداری کنیم تا بتونیم از این آرایه در ویو استفاده کنیم. برای این کار می تونید از دستور زیر استفاده کنید
کنترلر
 ViewBag.Users = _context.Users.Tolist();
حالا میتونیم وقتی ویو Load شد این ViewBag رو دریافت کنیم.
      $(document).ready(function () {
            var array = [];
            array = JSON.parse('@Html.Raw(
                        Json.Serialize(
                            ((IEnumerable<Users_Tbl>)ViewBag.Users).Select(user=> new
                                {
                                    userId = user.userId ,
                                    userName = user.userName ,
                                    address = user.address ,
                                    phoneNo = user.phoneNo ,
                                })
                            )
                        )');
        });
توسط دستورات بالا شما یک آرایه دارید به نام array که شامل لیست Users هایی هست که از سمت کنترلر اومده.
نمایش آرایه در جی کوئری
توسط دستور زیر می تونید مقدار محتویات این آرایه رو نمایش بدید
console.log(array);
دسترسی به سلولهای آرایه در جی کوئری
با استفاده از دستور زیر می تونید به سلولهای آرایه دسترسی داشته باشید
array.find(x => x.userid === '45').address;
- آموزش استفاده از پلاگین گردونه شانس در Asp.net core به همراه سورس
- نمایش متن به صورت فرمت شده در CkEditor
- آموزش استفاده از SignalR در Asp.net Core با مثال عملی
- ادغام چند گزارش استیمول سافت بصورت پی دی اف در یک فایل
- نحوه تغییر استایل کامپوننت select2 چگونه است ؟
- چگونه امنیت پروژه را در Asp.net Core افزایش دهیم ؟
- ارسال پارامتر در دستور window.open جی کویری
- ارسال پارامتر از طریق جاوااسکریپت با کلیک روی تگ a
- خطای 500 زمان اجرا شدن پروژه روی هاست
- کویری نویسی در استیمول سافت جهت فیلتر اطلاعات
- کار با CkEditor با قابلیت آپلود عکس
- خطا در ایجاد migration در Asp.net core
- تفاوت های Asp.net core و Asp.net mvc چیه؟
- دلیل اسپم شدن ایمیل های ارسالی از سرور
- نحوه لایه بندی پروژه Core و اضافه کردن به IIS
- ارسال ایمیل در Asp.net core
- آیا میشه در mvc core از کامپونت استفاده کرد
- آپلود فایل در Asp.net core چگونه است؟
- حذف کامل یک رکورد در جدول ریلیشن شده
- اشکال در آپلود فایل ویدیو در mvc core 2
 
                         
                         
                        