- vừa được xem lúc

Cấu hình menu cho trang web bằng EzyPlatform và sử dụng nhiều ngôn ngữ cho trang web

0 0 9

Người đăng: Việt

Theo Viblo Asia

Cấu hình menu cho trang web bằng EzyPlatform

B1: tạo class Service gọi tới WebMenuItemService và WebMenuRepository để thực hiện lấy dữ liệu menu từ phía Admin tạo ra với các thông tin sau

 private final WebMenuItemService menuItemService; private final WebMenuRepository menuRepository; public List<MenuItemModel> getMaiMenuItems() { //tìm kiếm menu bằng tên Menu menu = menuRepository.findByField("name", "main"); return menuItemService.getMenuItemsByMenuId( menu.getId() ); }

B2: sau khi đã thực hiện khởi tạo class Service phía Controller sẽ tiến hành gửi thông tin lưu vào View để gửi dữ liệu tới giao diện

trong View.builder() thêm thuộc tính:

.addVariable (
"mainMenuItems",
[Class Service].getMainMenuItems()
)
@Controller
@AllArgsConstructor
public class HomeController { private final WebBlogMenuItemService blogMenuItemService; @DoGet("/") public View home() { return View.builder() .template("home") .addVariable( "mainMenuItems", blogMenuItemService.getMaiMenuItems() ) .addVariable(VIEW_VARIABLE_PAGE_TITLE, "home") .build(); }
}

B3: sau khi hoàn tất thao tác phía giao diện sử dụng thymleaf để lặp qua các menuItems

<li th:each="mainMenuItem : ${mainMenuItems}" > [[${mainMenuItem.linkText}]]
</li>
  • Trong MenuItemModel có chứa các thuộc tính sau:
 private long id; private String linkText; private String linkType; private String customLink; private long linkId; private int level; private long orderValue; private long parentId; 

B4: sau khi đã hoàn thành các bước trên, chúng ta chạy server admin và khởi tạo menu:

  • b1: chọn menu
  • b2: đặt tên menu
  • b3: lưu lại thông tin menu

sau khi tạo xong chúng ta sẽ thêm các thông tin cho menu

  1. chọn Customize Links
  2. chọn add new và điền các thông tin như tên và URL

khi thêm thông tin xong, phía customize Links sẽ xuất hiện thông tin menu đã thêm, chúng ta chọn và thêm vào menu

khi đã hoàn thành tất cả các thao tác trên, chúng ta sẽ chạy lại chương trình và kiểm tra, thông tin menu sẽ xuất hiện

**Cấu hình web đa ngôn ngữ với ezyPlatform **

B1: trong folder [project_name]_theme\src\main\java\view

  • tạo Class Web[name]ViewDecorator extends tới WebViewDecorator ví dụ:
@EzySingleton
public class WebBlogViewDecorator extends WebViewDecorator {}

B2: trong folder [project_name]_theme\src\main\resources\mesages\Resource Bundle ‘messages’

tạo file message[ngôn ngữ].properties và điền các thông tin ngôn ngữ cần chuyển đổi, vd:

trong message_vi.properties: chứa các thông tin như

home= Trang chủ
posts= Danh sách bài viết
contact_me = Thông tin liên hệ
about_me = Giới thiệu

Bình luận

Bài viết tương tự

- vừa được xem lúc

EzyPlatform - Giới thiệu về nền tảng Lập trình từ người Việt

Giới thiệu về Ezyplatform - Nền tảng lập trình từ người Việt. Ezyplatform là gì.

0 0 19

- vừa được xem lúc

EzyPlatform - Tạo blog dễ dàng với EzyBlog - Không cần code hay thiết kế

Giới thiệu. Bạn muốn tạo một trang blog nhưng không muốn đối mặt với sự phức tạp của việc lập trình hay thiết kế web? Đừng lo, EzyPlatform là giải pháp cho bạn.

0 0 20

- vừa được xem lúc

EzyPlatform - Cách tích hợp đăng nhập nhanh chóng với EzyLogin - Không cần code hay thiết kế

Giới thiệu. Bạn muốn tạo một trang web với tính năng đăng nhập, đăng ký cho người dùng, nhưng không muốn phải đối mặt với sự phức tạp của việc lập trình hay thiết kế giao diện đăng nhập? Đừng lo, EzyL

0 0 18

- vừa được xem lúc

Tích hợp Đăng nhập với Google vào Ứng dụng Web với EzyLogin - Phần 2

Giới thiệu. Trong phần 1, chúng ta đã khám phá cách tích hợp tính năng đăng nhập và đăng ký cơ bản vào ứng dụng web của bạn bằng EzyLogin.

0 0 29

- vừa được xem lúc

Tích hợp Đăng nhập với Facebook vào Ứng dụng Web với EzyLogin - Phần 3

Giới thiệu. Trong phần 2 chúng ta đã tìm hiểu cách tích hợp tính năng đăng nhập và đăng ký bằng Google với EzyLogin.

0 0 21

- vừa được xem lúc

Tạo dự án EzyPlatform

Khởi tạo project. Bước 1: Cài đặt SDK và giải nén. . Bước 3: Thêm %EZYPLATFORM_SDK%in vào biến path.

0 0 12