ArmNo

โค้ดสำคัญสำหรับ WordPress Theme หากเปิดใช้งาน Threaded Comments

ประสบการณ์อย่างหนึ่งจากการทำธีม Notte ก็คือ เวลาทำธีมเสร็จ และเปิดใช้งาน Threaded Comments (ฟีเจอร์พื้นฐานของ WordPress) พบว่า หากดปุ่ม Reply ของแต่ละคอมเม้นต์ ต้องรอเพจโหลดสักครู่ (รีโหลดหน้าใหม่) ต่างจากธีมอื่นๆที่พอกด reply ปุ๊บ ฟอร์มคอมเม้นต์ก็จะมาอยู่ใต้คอมเม้นนั้นปั๊บ ไม่ต้องรอโหลดหน้าเพจใหม่ .. ด้วยความสงสัย จึงไปหาคำตอบมาครับ

เปิด Console ใน Firebug ดู ถึงได้รู้ว่าพอกด reply จะมี error ของ JavaScript เกิดขึ้น แสดงว่า มันน่าจะหาฟังก์ชั่น addComment ไม่เจอ .. ฟังก์ชั่นนี้ผมไม่ได้เขียนเองครับ จึงพอเดาได้ว่า น่าจะเป็นของ WordPress .. และสาเหตุที่น่าจะทำให้เกิด error นี้ก็คือ น่าจะลืม include ไฟล์ JavaScript ที่มีฟังก์ชั่นนี้อยู่ เข้าในในเพจของเราครับ

image

ก็เลยไปแงะโค้ดของ Twenty Ten ดู พบว่า ผมลืมใส่โค้ดนี้ลงไปในแท็ก <head>

image

ใน if block นะครับ เป็นการบอกว่า หากเพจนี้เป็น single page และบล็อกเราได้เปิดใช้งาน threaded comments ไว้ ให้โหลด JavaScript ชื่อว่า comment-reply เข้ามาด้วย ซึ่งไฟล์นี้แหละครับที่มีฟังก์ชั่น addComment ที่หายไป Open-mouthed smile

ทีนี้พอกด reply ฟอร์มคอมเม้นต์จะเด้งไปใต้คอมเม้นท์ที่เรากด reply ให้ทันที รวมถึงกด cancel ฟอร์มก็จะเด้งกลับไปที่เดิมให้ด้วย .. ไม่ต้องรอโหลดให้เสียเวลา Winking smile

image

อย่าลืมนะครับ ใส่โค้ดนี้ในแท็ก <head> ในธีมด้วย หากเปิดใช้งาน Threaded Comments ครับ

if (is_singular() && get_option('thread_comments')) { wp_enqueue_script('comment-reply'); }

3 Comments

  1. รถกอล์ฟ

    January 9, 2011 Firefox 3.6.10 Ubuntu 10.04

    เข้าใจทันที ก็ว่าอยู่มันหายไปไหน ^_^

  2. รับทำเว็บไซต์

    July 11, 2011 Chrome 12.0.742.112 Windows 7

    ขอบคุณครับ มีประโยชน์สำหรับมือใหม่มาก

  3. Chiangmai Tattoo

    August 8, 2011 Chrome 13.0.782.107 Windows 7

    เยี่ยมครับ ได้แนวทางเลย

Leave a Comment

*