Định tạm dừng seri về lập trình theme WooCommerce rồi :D, nhưng lại được yêu cầu từ vài bạn trên fan page Blog Huy Kira nên hôm nay mình tiếp tục cho ra một bài mới về chủ đề này.

Bài viết hôm này mình sẽ giới thiệu cho các bạn chức năng sản phẩm đã xem trong WooCommerce.

Hướng dẫn xây dựng chức năng sản phẩm đã xem trong WooCommerce

Phân tích kỹ thuật

Sản phẩm đã xem ở đây được xác định khi chúng ta vào xem trang chi tiết của một sản phẩm. Cứ mỗi lần xem thì website sẽ ghi nhớ và sau đó sẽ hiển thị list danh sách sản phẩm mà chúng ta đã vào xem trang chi tiết.

Việc quan trọng ở đây là phải ghi nhớ mỗi lần user vào trang chi tiết sản phẩm. Để làm điều này mình sẽ sử dụng chức năng session trong PHP.

Cụ thể như sau:

Chúng ta khởi tạo một session có key là viewed giá trị ban đầu sẽ là một mảng rỗng. Cứ mỗi lần vào trang chi tiết sản phẩm thì chúng ta lấy ID của sản phẩm đó thêm vào mảng session, mảng session  đó chính là danh sách ID của các sản phẩm cần lấy.

Việc cuối là chúng ta sẽ sử dụng vòng lặp get post trong wordpress để show sản phẩm ra như mong muốn.

Xây dựng chức năng sản phẩm đã xem

Để xây dựng chức năng này chúng ta sẽ làm 2 việc chính đó là:

  • Khởi tạo session và lưu ID của từng sản phẩm khi truy cập vào bài viết chi tiết của sản phẩm đó
  • Sử dụng mảng session để show danh sách sản phẩm

Khởi tạo session:

Các bạn chèn đoạn code này vào file functions.php của theme đang sử dụng nha:

Chúng ta sẽ tạo một hàm có tên là viewedProduct trong hàm này sẽ thực hiện các công việc như sau:

  • session_start(); là cú pháp khởi tạo session
  • Dòng 3, 4, 5 là kiểm tra thử có tồn tại session viewed hay không. Nếu chưa có thì tạo một session có key là viewed giá trị của session này là một mảng rỗng.
  • Dòng 6, 7, 8 kiểm tra có đang ở trang chi tiết sản phẩm hay không bằng cách sử dụng làm is_singular(‘product’). Nếu đang ở trang chi tiết sản phẩm thì thêm một phần từ mới là ID sản phẩm vào session vừa khởi tạo ở trên.
  • Dòng 10 móc hàm này vào action wp để chạy hàm trên khi mỗi lần load website.

Sau khi chạy đoạn code này chúng ta sẽ được một session có key là viewed và giá trị sẽ là mảng các ID của sản phẩm đã xem.

Hiển thị danh sách sản phẩm:

Để hiển thị list các sản phẩm đã xem các bạn chèn đoạn code sau vào vị trí cần hiển thị nha.

Đoạn code trên mình tiến hành kiểm trả session có key là viewed có tồn tại hay không, nếu có chúng ta sẽ chạy vòng lặp get post vào show những sản phẩm đã xem ra.

Còn nếu không có sản phẩm nào đã xem thì hiển thị dòng thông báo: Không có sản phẩm nào đã xem!

Chú ý: ‘post__in’ => $data là điều kiện để nó hiện các sản phẩm với một mảng id sản phẩm có trước.

Tổng kết:

Hôm nay mình đã hướng dẫn cho các bạn chức năng sản phẩm đã xem trong WooCommerce. Chức năng cũng khá đơn giản sử dụng một tí session là xong.

Session nó lưu dữ liệu trong thời gian trình duyệt đang hoạt động. Nếu chúng ta tắt trình duyệt thì nó sẽ tự xóa dữ liệu, tương đương với việc các sản phẩm trên sẽ bị reset.

Nếu các bạn không muốn bị mất danh sách đã xem sau khi tắt trình duyệt các bạn có thể sử dụng cookies nha.

Thời gian tới mình sẽ tiếp tục ra các video hướng dẫn lập trình wordpress, các bạn nhớ like page vào theo dõi blog nha!

Chào các bạn!

Huy Kira

Đam mê hóa học, ưng thi vào trường kinh tế... Đậu vào trường Sư phạm, quyết tâm đi dạy... Ra trường đi làm designer, tự học frontend, chuyển qua làm PHP, được công ty đào tạo laravel... Và hiện tại đang code react native... 😂😂 tối về viết blog... (Còn tiếp...)

3
  • Nhựtbạn xem giùm mình được không ? trên destop thì hiện đúng nhưng mobile thì không hiện mà chỉ hiện đúng 1 sản phẩm đang xem. Giúp mình xem lỗi như thế nào

    Thích Trả lời 2 tháng trước

  • Vu NguyenCái này có nhược điểm là khi tắt trình duyệt là session bị xóa luôn. Còn những website khi làm chức năng này, khoản 1 tháng hoặc 1 tuần sau, họ vào lại thì vẫn còn lưu sản phẩm đã xem của họ. Ví dụ như: website memoryzone .com .vn. Hi vọng có thêm update mới.

    Thích Trả lời 1 tháng trước

  • senityHay quá anh ơi, cảm ơn bài viết của anh ạ

    Thích Trả lời 4 tuần trước

AVT