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

نکته: در این مقاله جهت آموزش وردپرس از پوسته twentyseventeen استفاده می کنیم.

فیلم آموزش ساخت دکمه مطالب بیشتر در وردپرس با Ajax

 

قدم اول – ساخت دکمه مطالب بیشتر

آموزش رو با ساخت دکمه “مطالب بیشتر” آغاز می کنیم ، فقط باید یک قانون رو رعایت کنیم: فقط زمانی دکمه نمایش داده میشه که مطلبی برای نمایش وجود داشته باشه و از طریق کد $wp_query->max_num_pages > 1 چک می کنیم.

کدهای زیر را در صفحه index.php در خط 61 وقبل از بسته شدن تگ <main> اضافه میکنیم ، و کدهای مربوط به pagination در خط 49 را پاک می کنیم:

برای اینکه دکمه زیباتر دیده بشه کدهای CSS زیر را به فایل Style.css اضافه میکنیم:

توجه: جهت فراگیری روش صحیح فراخوانی CSS در قالب وردپرس به این مقاله آموزش وردپرس مراجعه کنید.

قدم دوم: انتقال پارامترها به اسکریپت

قطعه کد زیر به شما اجازه میدهد پارامترهای لازم را به اسکریپت انتقال داده و همین موضوع باعث شده که دکمه “مطالب بیشتر” در تمام صفحات tags، categories، post type archives، search قابل استفاده باشد.

کد زیر را به فایل functions.php اضافه می کنیم:

توجه: برای درک بهتره تابع بالا توصیه می شود مقاله wp_enqueue در وردپرس و تابع wp_localize_script در وردپرس را مطالعه کنید.

 قدم سوم: اسکریپت myloadmore.js

یک فایل به نام myloadmore.js در دایرکتوری پوسته twentyseventeen ساخته و کدهای زیر را به آن اضافه میکنیم:

کدهای بالا جهت ایجاد ارتباط ajax و فراخوانی تابع مورد نظر جهت دریافت اطلاعات مربوط به مطلب بعدی و افزودن آن به انتهای آخرین مطلب می باشد.

نکته: با توجه به قالب مورد استفاده، خط 17 می تواند متفاوت باشد و به ساختار HTML قالب مورد استفاده بستگی دارد.

قدم چهارم:  کدهای PHP برای Ajax

قدم بعدی افزودن کدهای لازم برای فراخوانی های ajax می باشد ، کدهای زیر را به functions.php اضافه می کنیم:

توجه : در خط 9 می توانید کدهای HTML دلخواه مرتبط با پوسته خود را قرار دهید و به دلیل استفاده از پوسته twentyseventeen از کد موجود استفاده شده است.

برای تست دکمه “مطالب بیشتر” ابتدا به قسمت تنظیمات و زیر منوی خواندن رفته و گزینه ” بیشترین تعداد نوشته‌ها در هر برگه‌ی وبلاگ ” را برابر با یک قرار داده و ذخیره می کنیم:

دکمه مطالب بیشتر در وردپرس با Ajax

مقاله دکمه مطالب بیشتر در وردپرس با Ajax به پایان رسید در صورتی که تمام مراحل بالا را پیاده سازی کرده باشید عملکردی مانند تصویر زیر خواهید داشت:

دکمه مطالب بیشتر در وردپرس با Ajax

توجه: در صورتیکه میخواهید بجای کلیک روی دکمه ، با اسکرول کردن مطالب بیشتری بارگذاری شده و نمایش داده شوند، کدهای مربوط به دکمه را در صفحه index.php پاک کرده و کدهای زیر را جایگزین کدهای موجود در فایل myloadmore.js کنید:

بروزرسانی : با تشکر از کاربر محترم ، Raymond Dragon کد ارسالی ایشون برای جایگزین کردن خط 9 در بخش چهارم.

کدهای بالا را جایگزین تابع get_template_part در بخش چهارم کنید.

نظرات و سوالاتتون رو در قسمت کامنت های همین مطلب برامون ارسال کنید.

موفق باشید

10 دیدگاه برای “دکمه مطالب بیشتر در وردپرس با Ajax + فیلم آموزشی

  • محمد مقدم
    - ۱۷ بهمن , ۱۳۹۶

    با سلام و احترام
    لطفا قرار دادن آیکن لودینگ قبل از بارگذاری تصاویر پست های سایت را آموزش دهید. دقیقا مانند این سایت
    http://www.hidoctor.ir/
    با تشکر بی صبرانه منتظر آموزش هستم…

    • سیروس
      - ۱۷ بهمن , ۱۳۹۶

      با سلام
      ممنون از نظرات شما ، حتما در اولین فرصت یک مقاله در این مورد آماده می کنیم
      موفق باشید

      • محمد مقدم
        - ۲۴ بهمن , ۱۳۹۶

        همچنان منتظیم…

        • سیروس
          - ۲۵ بهمن , ۱۳۹۶

          مقاله درخواستی شما آماده شده و بزودی در سایت منتشر می شود.

  • Raymond Dragon
    - ۱۰ اسفند , ۱۳۹۶

    درود…در قسمت کدهای PHP برای Ajax قرار بود صفحه بخواد در آن دکمه لودینگ قرار بگیرد به مشکل بر خوردم…این خطا می دهد:
    Parse error: syntax error, unexpected ‘<' in C:\xampp\htdocs\wordpress\wp-content\themes\neon\functions.php on line 115
    متاسفانه توی ویدیو آموزش قسمت چهارم ناقص بود مشکلی که داره هر کدی که بخوام در این مکان قرار بگیره سازگار نداره و با کدها تداخل داره…
    لطفا مشکل رو سریعا حل کنید ممنون میشم جواب بدید…

    • سیروس
      - ۱۰ اسفند , ۱۳۹۶

      با سلام و خسته نباشید
      من ویدئو رو بررسی کردم متوجه نشدم منظورتون از ناقص بودن بخش چهارم ویدئو دقیقا چیه؟
      بنده احتمال میدم مشکل از کدهایی که شما اضافه کردید باشه.
      در هر صورت کدهاتون رو برای ما از طریق تلگرام بفرستید تا کمکتون کنیم برای حل مشکل ایجادشده.

      https://t.me/wpschool_support

      با تشکر

  • Raymond Dragon
    - ۱۱ اسفند , ۱۳۹۶

    ببخشید ناقص ارسال شد:
    https://paste.ubuntu.ir/ztot

    • سیروس
      - ۱۲ اسفند , ۱۳۹۶

      با سلام
      کد شما دو مشکل داشت ، اول اینکه باید بالای کد شما تگ php بسته و انتهای کد شما مجدد تگ php باز بشه
      مورد دوم اینکه تابع the_views به صورت پیش فرض وجود نداره و با حذف اون خطای موجود در کد از بین میره
      کد اصلاح شده در تلگرام برای شما ارسال شد و برای استفاده بقیه کاربران به انتهای پست اضافه میشه
      با تشکر

  • دولوپر
    - ۱۰ مهر , ۱۳۹۷

    با سلام
    مشکل من خیلی حاده ، تمامی روشهای تو نت مثل روش شما رو امتحان کردم و همیشه به ارور زیر میخورم:
    SyntaxError: JSON.parse: unexpected character at line 4 column 3 of the JSON data

    علت چی میتونه باشه؟؟ ممنون میشم راهنمایی کنید که به شدت نیاز دارم

    • سیروس
      - ۱۰ مهر , ۱۳۹۷

      سلام می تونه دلیل های زیادی داشته باشه ، اول باید خروجی رو چاپ کنید ببینید چی هست و بعد مشکل رو حل کنید توصیه میکنم اول خروجی تون رو print_r کنید و بعد ادامه بدید. اگه بازم مشکل رو متوجه نشید با تلگرام مدرسه وردپرس در ارتباط باشید:
      https://t.me/wpschool_support

دیدگاه خود را بیان کنید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

Captcha loading...