ویژگی تصویر

رویداد oninput در JavaScript

  /  جاوا اسکریپت   /  رویداد oninput در جاوا اسکریپت
بنر تبلیغاتی الف
جاوااسکریپت - JavaScript

در این بخش به بررسی رویداد oninput در جاوا اسکریپت می پردازیم، در دنیای توسعه وب، جاوا اسکریپت به عنوان یکی از محبوب‌ترین زبان‌های برنامه‌نویسی شناخته می‌شود که به برنامه‌نویسان اجازه می‌دهد تا رفتارهای پویایی را در صفحات وب پیاده‌سازی کنند. یکی از ابزارهای قدرتمندی که جاوا اسکریپت در اختیار توسعه‌دهندگان قرار می‌دهد، رویدادها (Events) هستند. رویدادها به ما این امکان را می‌دهند که به تعاملات کاربر با صفحه وب واکنش نشان دهیم، مثلاً وقتی کاربر روی دکمه‌ای کلیک می‌کند یا محتوای فیلدی را تغییر می‌دهد.

رویداد oninput یکی از این رویدادها است که بیشتر در هنگام کار با فرم‌ها و فیلدهای ورودی استفاده می‌شود. این رویداد زمانی فعال می‌شود که محتوای فیلد ورودی کاربر تغییر کند. در این مقاله به بررسی کامل رویداد oninput در جاوا اسکریپت می‌پردازیم و با توضیحات دقیق و مثال‌های کاربردی نشان خواهیم داد که چگونه می‌توان از این رویداد برای ایجاد تعاملات پویا و هوشمند استفاده کرد.

رویداد oninput چیست؟

رویداد oninput در جاوا اسکریپت زمانی فراخوانی می‌شود که محتوای یک فیلد ورودی، مانند input یا textarea، تغییر کند. برخلاف رویداد onchange که تنها زمانی فعال می‌شود که کاربر تغییرات را تایید کند (مثلاً پس از خروج از فیلد ورودی)، oninput به محض اینکه تغییری در محتوای فیلد رخ دهد، اجرا می‌شود. این ویژگی، رویداد oninput را برای پیاده‌سازی تعاملات زنده (real-time) و فوری بسیار مناسب می‌سازد.

به عنوان مثال، فرض کنید کاربری در حال تایپ در یک فیلد جستجو است. با استفاده از رویداد oninput می‌توانیم به محض تایپ هر حرف، نتایج جستجو را به‌روزرسانی کنیم، بدون نیاز به فشردن دکمه‌ای برای ارسال فرم.

تفاوت oninput و onchange

اگرچه ممکن است به نظر برسد که رویدادهای oninput و onchange مشابه هستند، اما تفاوت کلیدی آن‌ها در زمان اجرای رویداد است. oninput با هر تغییر کوچکی در لحظه اجرا می‌شود، اما onchange تنها زمانی فعال می‌شود که کاربر تغییرات را نهایی کرده و از فیلد خارج شود. این تفاوت برای کاربردهایی که نیاز به پاسخ‌دهی لحظه‌ای دارند، اهمیت زیادی دارد.

استفاده از oninput در جاوا اسکریپت

برای استفاده از رویداد oninput می‌توانید آن را به یک فیلد ورودی یا textarea اضافه کنید. این کار را می‌توان هم از طریق HTML و هم با استفاده از جاوا اسکریپت انجام داد. در ادامه هر دو روش را بررسی می‌کنیم:

استفاده از oninput در HTML

در این روش، به‌راحتی می‌توانیم رویداد oninput را مستقیماً در تگ HTML تعریف کنیم. به مثال زیر توجه کنید:

<input type="text" id="nameInput" oninput="handleInput()" placeholder="نام خود را وارد کنید">

در این کد، هر زمان که کاربر شروع به تایپ در فیلد ورودی کند، تابع جاوا اسکریپتی handleInput اجرا می‌شود. حال تابع handleInput را در بخش جاوا اسکریپت تعریف می‌کنیم:

تماشا در حالت تمام صفحه

با هر بار تغییر محتوا در فیلد ورودی، پیام جدیدی در کنسول نمایش داده می‌شود که نشان می‌دهد کاربر چه محتوایی وارد کرده است.

استفاده از oninput در جاوا اسکریپت

در روش دیگر، می‌توان رویداد oninput را با استفاده از جاوا اسکریپت به فیلد اضافه کرد. این روش به‌ویژه زمانی مفید است که بخواهیم رویدادها را به‌صورت پویا و بدون نیاز به تغییر مستقیم HTML اضافه کنیم.

<input type="text" id="nameInput" placeholder="نام خود را وارد کنید">
تماشا در حالت تمام صفحه

در این مثال، رویداد oninput با استفاده از جاوا اسکریپت به فیلد ورودی متصل شده است. همانند مثال قبلی، با هر بار تغییر محتوای فیلد، متن وارد شده در کنسول نمایش داده می‌شود.

کاربردهای عملی oninput

رویداد oninput می‌تواند در بسیاری از کاربردهای عملی در صفحات وب مورد استفاده قرار گیرد. برخی از این کاربردها شامل بررسی اعتبارسنجی لحظه‌ای ورودی‌ها، ایجاد پیشنهادات جستجو زنده و همچنین به‌روزرسانی زنده داده‌ها است. در این بخش به بررسی چند نمونه کاربرد عملی می‌پردازیم.

1. اعتبارسنجی لحظه‌ای ورودی

یکی از کاربردهای رایج رویداد oninput اعتبارسنجی لحظه‌ای اطلاعات وارد شده توسط کاربر است. فرض کنید که می‌خواهید کاربر به‌محض وارد کردن ایمیل، از صحیح بودن فرمت آن مطمئن شود. برای این کار می‌توان از oninput استفاده کرد تا با هر بار تغییر در فیلد ایمیل، فرمت ورودی بررسی شود:

<input type="email" id="emailInput" placeholder="ایمیل خود را وارد کنید" oninput="validateEmail()">
<p id="emailError" style="color: red;"></p>
تماشا در حالت تمام صفحه

در این مثال، وقتی کاربر شروع به تایپ ایمیل خود می‌کند، سیستم به صورت زنده بررسی می‌کند که آیا فرمت ایمیل صحیح است یا خیر. اگر ایمیل نادرست باشد، پیغام خطا نمایش داده می‌شود.

2. پیشنهادات جستجوی زنده

یکی دیگر از کاربردهای جذاب رویداد oninput ایجاد پیشنهادات جستجوی زنده است. فرض کنید کاربر در یک سایت فروشگاهی به دنبال محصول خاصی می‌گردد. با استفاده از رویداد oninput می‌توانیم به محض تایپ هر حرف، نتایج پیشنهادی را به کاربر نمایش دهیم.

<input type="text" id="searchInput" placeholder="جستجوی محصول" oninput="searchProduct()">
<div id="suggestions"></div>
تماشا در حالت تمام صفحه

در این مثال، به محض تایپ در فیلد جستجو، پیشنهادات محصولات مرتبط با عبارت وارد شده به صورت لحظه‌ای نمایش داده می‌شوند.

بهینه‌سازی عملکرد oninput

اگرچه رویداد oninput بسیار قدرتمند است، اما در مواردی که پردازش‌های سنگینی نیاز باشد (مانند فراخوانی API‌ها)، ممکن است بهینه‌سازی‌هایی نیاز باشد. برای این کار می‌توانیم از روش‌هایی مانند “دیباونس” (debounce) استفاده کنیم. در این روش، اطمینان حاصل می‌کنیم که تابع متصل به oninput تنها پس از یک بازه زمانی مشخص و در صورتی که کاربر دیگر ورودی‌ای نداشته باشد، اجرا شود.

تماشا در حالت تمام صفحه

در این مثال، تابع مرتبط با oninput تنها پس از ۵۰۰ میلی‌ثانیه عدم فعالیت کاربر اجرا می‌شود، که این کار به جلوگیری از اجرای مکرر کد و بهبود کارایی کمک می‌کند.

رویداد oninput در جاوا اسکریپت ابزاری مفید و قدرتمند برای ایجاد تعاملات لحظه‌ای و پاسخ‌گویی سریع به تغییرات کاربر است. با استفاده از این رویداد می‌توان به‌راحتی اعتبارسنجی‌های زنده، جستجوهای فوری و دیگر کاربردهای تعاملی را پیاده‌سازی کرد. به‌کارگیری درست این رویداد می‌تواند تجربه کاربری را بهبود داده و تعاملات پویاتری در صفحات وب ایجاد کند.

منابع:

  • Mozilla Developer Network (MDN): oninput event
  • W3Schools: HTML DOM oninput Event

آیا این مطلب برای شما مفید بود ؟

خیر
بله
بنر تبلیغاتی ج