ویژگی تصویر

آموزش ایجاد فرم تماس بدون افزونه در وردپرس

  /  وردپرس   /  ایجاد فرم تماس بدون افزونه در وردپرس با PHP و Ajax
بنر تبلیغاتی الف
wp - wordpress - وردپرس

در دنیای وب، فرم‌های تماس یکی از اجزای مهم برای تعامل با کاربران هستند. اگرچه وردپرس به طور پیش فرض از افزونه‌ها برای این کار استفاده می‌کند، اما در بسیاری از مواقع، دسترسی به فرم تماس بدون نیاز به افزونه، ترجیح داده می‌شود. در این مقاله، نحوه ساخت یک فرم تماس با استفاده از PHP و Ajax در وردپرس را به طور کامل شرح می‌دهیم.

نحوه عملکرد اصلی

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

برای این منظور، ابتدا نیاز به یک قالب (theme) ساده داریم و در آن فرم تماس را ایجاد کرده و سپس با استفاده از Ajax، اطلاعات را به PHP ارسال می‌کنیم. PHP نیز، اطلاعات را پردازش کرده و در صورت لزوم، پاسخی به کاربر ارسال می‌کند.

فرم تماس ساده

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

<form id="contact-form">
    <input type="text" name="name" placeholder="نام"><br>
    <input type="email" name="email" placeholder="ایمیل"><br>
    <input type="text" name="subject" placeholder="موضوع"><br>
    <textarea name="message" placeholder="پیام"></textarea><br>
    <button type="submit">ارسال</button>
</form>

این فرم با استفاده از HTML ساده ایجاد شده است. در این مرحله، فرم هنوز کار نمی‌کند، زیرا ما هنوز آن را با Ajax و PHP متصل نکرده‌ایم.

افزودن Ajax به فرم

برای ارسال فرم بدون بارگذاری صفحه، از JavaScript و Ajax استفاده می‌کنیم. در اینجا یک نمونه کد جاوااسکریپت آورده شده است:

jQuery(document).ready(function($) {
    $('#contact-form').on('submit', function(e) {
        e.preventDefault();
        var formData = $(this).serialize();
        $.ajax({
            url: ajaxurl,
            type: 'POST',
            data: formData + '&action=send_contact_message',
            success: function(response) {
                alert(response);
            }
        });
    });
});

در این کد، ابتدا فرم را از رویداد submit متوقف می‌کنیم (preventDefault). سپس داده‌ها را با استفاده از serialize() جمع‌آوری کرده و با Ajax به سرور ارسال می‌کنیم. اطلاعات به action send_contact_message اضافه شده‌اند، که بعداً در PHP پردازش خواهد شد.

پردازش داده‌ها در PHP

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

function send_contact_message() {
    if (isset($_POST['name']) && isset($_POST['email']) && isset($_POST['subject']) && isset($_POST['message'])) {
        $name = sanitize_text_field($_POST['name']);
        $email = sanitize_email($_POST['email']);
        $subject = sanitize_text_field($_POST['subject']);
        $message = sanitize_textarea_field($_POST['message']);

        // ارسال ایمیل
        $to = get_option('admin_email');
        $mail_subject = 'فرم تماس: ' . $subject;
        $body = "نام: $namenایمیل: $emailnپیام:n$message";
        wp_mail($to, $mail_subject, $body);

        echo 'پیام شما با موفقیت ارسال شد.';
    } else {
        echo 'لطفاً تمام فیلدها را پر کنید.';
    }
    wp_die();
}
add_action('wp_ajax_send_contact_message', 'send_contact_message');
add_action('wp_ajax_nopriv_send_contact_message', 'send_contact_message');

در این فانکشن، ابتدا داده‌های ورودی را با استفاده از sanitize_text_field و sanitize_email چک می‌کنیم. سپس اطلاعات را در قالب ایمیل به مدیر سایت ارسال می‌کنیم. در نهایت، پاسخی به کاربر ارسال می‌شود. همچنین دو action وجود دارد: یکی برای کاربران وارد شده و دیگری برای کاربران غیرثبت‌نام.

پیاده‌سازی نهایی

برای اجرای این فرم، باید فایل functions.php را در قالب وردپرس خود به‌روز کنیم و اطمینان حاصل کنیم که jQuery در صفحات فعال است. همچنین باید متغیر ajaxurl را در فایل JavaScript خود در دسترس قرار دهیم.

در پایان، فرم تماس شما با استفاده از PHP و Ajax بدون نیاز به افزونه کار می‌کند. در صورت وجود مشکلات در ارسال ایمیل یا نمایش پاسخ، باید از فانکشن wp_mail و پیام‌های خطا استفاده کنید.

مزایا و معایب

مزایامعایب
عدم نیاز به افزونهنیاز به دانش PHP و JavaScript
سرعت بالاترپیاده‌سازی سخت‌تر
قابلیت سفارشی‌سازی بیشترعدم پشتیبانی از افزونه‌های خارجی

بهینه‌سازی و نکات مهم

برای بهینه‌سازی فرم تماس، ابتدا باید از اعتبارسنجی داده‌ها استفاده کنید. همچنین از ساختاری مانند CAPTCHA برای جلوگیری از ارسال‌های خودکار استفاده کنید.

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

نتیجه‌گیری

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

در این روش، شما می‌توانید به صورت سفارشی و با استفاده از فانکشن‌های PHP و JavaScript، اطلاعات کاربران را جمع‌آوری و پردازش کنید. در نهایت، این فرم می‌تواند به طور مؤثر با سیستم ایمیل وردپرس ارتباط برقرار کند.

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

خیر
بله
موضوعات شما در انجمن: