Bootstrap

Vũ Thành Lâm

Content - Code - SEO - MMO
17/10/1979
Tây Mỗ - Nam Từ Liêm - Hà Nội
thanhlam19792003

Lamvt – Vũ Thành Lâm – bắt đầu Code 2005 Freelancer từ 2006 với hàng ngàn dự án lớn nhỏ cho nước ngoài và hàng trăm dự án web cho Việt Nam.

SEO thành công rất nhiều dự án lớn, độ khó cao.
MOD (Moderator) và Admin (Administraror) của nhiều diễn đàn về SEO và CODE web MMO tại Việt Nam
Dạy Lập trình Thiết kế Web và SEO Miễn phí 17++ Năm (Từ 2006 đến Nay)

Kết hợp jQuery Masonry và Infinite Scroll để lấy Newsfeed như Tumblr dạng block

5/5 - (4 bình chọn)

Như chúng ta đã biết, để lấy Newsfeed dạng cuộn đến cuối trang và load thêm trang tin giống như Facebook (live feed), Twitter, Pinterest, Feedly… đã được hướng dẫn của bài trước dùng cho WordPress: Cách thêm Infinite Scrolling WordPress lấy tin như Facebook Feed

Nhưng để đặt các bản tin này theo dạng các khối xắp xếp cho chuẩn theo vị trí gọn gàng và chuyên nghiệp như Tumblr hoặc các bạn có thể xem demo như: https://lamvt.vn thì ta làm như thế nào.

Nhiều người hiểu về jQuery Masonry và cách sử dụng của nó là để dùng cho việc xắp xếp các block theo dạng khối bố trí lưới để cho các vị trí được xắp xếp tự động, còn plugin jQuery Infinite Scroll có thể cuộn tin theo dạng Newsfeed rất đẹp mặt. Vậy làm thế nào để kết hợp được 2 Plugin của jQuery này áp dụng cho WordPress.

Kết hợp jQuery Masonry và Infinite Scroll để lấy Newsfeed như Tumblr dạng block 2016-02-29_071343

Trước tiên để làm được điều này các bạn cần làm theo và năm rõ về jQuery Masonry và plugin của nó với WordPress.

Để làmđiều này chúng ta cần tải file masonry jQuery tại: https://github.com/desandro/masonry/raw/master/dist/masonry.pkgd.min.js và đặt vào trong folder js trong theme của mình.

Mở file Functions.php thêm dong lệnh sau:

    <?php
    /*************************
    WEB REVENUE INFINITE SCROLLING
    *************************/
    /*
    Function that will register and enqueue the infinite scolling’s script to be used in the theme.
    */
    function twentytwelve_script_infinite_scrolling(){
    wp_register_script(
    ‘infinite_scrolling’,//name of script
    get_template_directory_uri().’/js/jquery.infinitescroll.min.js’,//where the file is
    array(‘jquery’),//this script requires a jquery script
    null,//don’t have a script version number
    true//script will de placed on footer
    );
    wp_register_script(
    ‘masonry’,//name of script
    get_template_directory_uri().’/js/masonry.pkgd.min.js’,//where the file is
    array(‘jquery’),//this script requires a jquery script
    null,//don’t have a script version number
    true//script will de placed on footer
    );

    if(!is_singular()){ //only when we have more than 1 post
    //we’ll load this script
    wp_enqueue_script(‘infinite_scrolling’);
    wp_enqueue_script(‘masonry’);
    }
    }

    //Register our custom scripts!
    add_action(‘wp_enqueue_scripts’, ‘twentytwelve_script_infinite_scrolling’);

    /*
    Function that will set infinite scrolling to be displayed in the page.
    */
    function set_infinite_scrolling(){

    if(!is_singular()){//again, only when we have more than 1 post
    //add js script below
    ?>
    <script type=”text/javascript”>
    /**
    * Infinite Scroll + Masonry + ImagesLoaded
    */

    jQuery(function ($) {

    // Main content container
    var $container = $(‘#content’);

    // Masonry + ImagesLoaded
    $container.imagesLoaded(function(){
    $container.masonry({
    // selector for entry content
    itemSelector: ‘.article’,
    //columnWidth: 80
    columnWidth: ‘.sizer’,
    percentPosition: true,
    //gutter:0
    });
    });

    // Infinite Scroll
    $container.infinitescroll({

    // selector for the paged navigation (it will be hidden)
    navSelector  : “#nav-below”,
    // selector for the NEXT link (to page 2)
    nextSelector : “#nav-below .nav-previous a”,
    // selector for all items you’ll retrieve
    itemSelector : “.article”,

    // finished message
    loading:{
    img: “<? echo get_template_directory_uri(); ?>/images/ajax-loader.gif”,
    msgText: “Loading next posts….”,
    finishedMsg: “Posts loaded!!”,
    },
    },

    // Trigger Masonry as a callback
    function( newElements ) {
    // hide new items while they are loading
    var $newElems = $( newElements ).css({ opacity: 0 });
    // ensure that images load before adding to masonry layout

    $newElems.imagesLoaded(function(){
    // show elems now they’re ready
    $newElems.animate({ opacity: 1 });
    $container.masonry( ‘appended’, $newElems, true );
    });

    });

    });

    </script>
    <?
    }
    }

    /*
    we need to add this action on page’s footer.
    100 is a priority number that correpond a later execution.
    */
    add_action( ‘wp_footer’, ‘set_infinite_scrolling’,100 );
    ?>

Như vậy giờ ta có thể kiểm tra kết quả của bạn tạo ra rồi

Chúc các bạn thành công
Cảm ơn anh ThanhLuu Leader của designwall -JOOM

Tin mới nhất

Dù bạn dùng phiên bản WordPress với lưu lượng truy cập cao hay một blog nhỏ trên máy chủ chia...

VR PLUS (https://vrplus.vn/ ) Là một trong những dự án do Lamvt thực hiện trong thời gian gần đây. Như...

Trong một năm qua, chúng tôi đã xuất bản khoảng 79 bài viết SEO trên blog Ahrefs. Các bài viết...

Khám phá kĩ thuật viết nội dung SEO Nếu không có SEO, nội dung của bạn có thể bị chìm...

Các website về lĩnh vực làm đẹp cần phải có một thiết kế (design) hấp dẫn và bắt mắt. Điều...

Tin được yêu thích

Như đã nói, phần mềm chỉnh sửa video đang ngày càng chứng tỏ được tầm quan trọng của mình, nhất...

Nhiều bạn thắc mắc là sau khi cài đặt Plugin cho Google AMP thì làm thế nào để kiểm tra,...

Các trang web giáo dục và các trang web của chính phủ có một lợi thế hơn trong bảng xếp...

Nội dung là một trong 3 tiêu chí quan trọng để google đánh giá thứ hạng tìm kiếm cho website...

Thẻ <span> </span> Thẻ <span> là thẻ khá đặc biệt trong HTML, theo mặc định thì thẻ <span> được thêm...

Khách đang xem

  1. “Đơn giản mà không tầm thường”. Điều này hoàn toàn đúng khi miêu tả về những chiếc nút kêu gọi...
    26 giây trước
  2. SEO là gì? Làm thế nào viết bài chuẩn SEO cho người mới bắt đầu? Bài viết hôm nay sẽ...
    27 giây trước
  3. Bạn muốn tìm kiếm một cái gì đó tốt, thông minh, hữu dụng hơn hầu hết mọi người tìm kiếm...
    28 giây trước
  4. Bước vào kỷ nguyên công nghệ hiện đại 4.0, cùng với sự phát triển mạnh mẽ của mạng xã hội...
    2 giây trước
  5. Quản lý việc tải lên thế nào khi người dùng không đăng nhập? Các vấn đề liên quan tới thông...
    30 giây trước
  6. SEO Đối với WordPress là một hướng dẫn chuyên sâu giúp cho người mới bắt đầu viết Blog và WordPress...
    10 giây trước
  7. SEO 2017 là một quá trình kỹ thuật, phân tích và sáng tạo để cải thiện khả năng hiển thị của...
    17 giây trước
  8. Nếu bạn có kế hoạch tích hợp Facebook vào thiết lập WordPress của mình, bạn có thể cài đặt một...
    21 giây trước
  9. Tổng quát Hướng dẫn Tổng quan Chào mừng bạn đến với Chương trình Xếp hạng Chất lượng tìm kiếm! Là...
    24 giây trước
  10. Thẻ <span> </span> Thẻ <span> là thẻ khá đặc biệt trong HTML, theo mặc định thì thẻ <span> được thêm...
    16 giây trước