SlideShare a Scribd company logo
1 of 56
Thiết kế giao diện với Liquid
Bizweb - 26/12/2015
Liquid là gì?
• Ngôn ngữ lập trình giao diện được phát triển bởi Shopify
• Mã nguồn mở, phát triển từ năm 2006
• Sử dụng để frontend có thể truy cập và lấy dữ liệu từ
backend một cách an toàn và dễ dàng.
Liquid code format
Các hệ thống đang sử dụng
Ưu điểm của Liquid
• Cấu trúc đơn giản, dễ nhớ, dễ sử dụng, thân thiện với Designer
• Bảo mật code trên server của bạn
• Kết hợp dễ dàng với cấu trúc HTML có sẵn.
• Người dùng có thể tự tùy biến giao diện hiển thị mà không cần
quan tâm đến backend.
• Tương đồng với Smarty, Twig
Liquid cơ bản
• Các toán tử (Operators)
• Kiểu dữ liệu (Types)
• Thẻ (Tags)
• Đối tượng (Objects)
• Bộ lọc (Filters)
Các toán tử
Liquid hỗ trợ các toán tử logic, so sánh và toán tử bao hàm.
== bằng
!= không bằng
> lớn hơn
< nhỏ hơn
>= lớn hơn hoặc bằng
<= nhỏ hơn hoặc bằng
or điều kiện A hoặc điều kiện B
and điều kiện A và điều kiện B
contains kiểm tra xem có sự xuất hiện của một chuỗi
{% if product.name == "Giày Converse" %}
Đây là đôi giày Converse
{% endif %}
{% if product.name contains 'Converse' %}
Đây là một sản phẩm của Converse
{% endif %}
Kiểu dữ liệu
Liquid hỗ trợ các kiểu dữ liệu cơ bản như:
• Chuỗi
• Số
• Boolean
• Mảng
Và ‘nil/null’ một giá trị rỗng được trả về khi thực thi một đoạn mã Liquid
mà không thể cho ra kết quả
Thẻ
Liquid sử dụng các thẻ logic để thông báo cho hệ thống cần trả về dữ
liệu là gì, các thẻ được bao bởi {% và %}
Thẻ điều khiển
luồng
Thẻ lặp Thẻ giao diện
Thẻ liên quan đến
biến
if for comment assign
elseif / else cycle include capture
case/when form increment
unless layout decrement
paginate
raw
<!-- Nếu customer.name = 'guest' -->
{% if customer.name == 'Gyo' %}
Chào bạn Gyo!
{% elsif customer.name == 'guest' %}
Xin chào quý khách!
{% else %}
Chào bạn!
{% endif %}
Đối tượng
Các đối tượng trong Liquid bao gồm các thuộc tính để xuất ra nội dung
động tương ứng, khi gọi các thuộc tính theo đối tượng tương ứng, sử
dụng {{ và }} để bao ngoài (ví dụ: {{ product.name }} ).
Các đối tượng tiêu biểu:
• collection
• product
• cart
• blog
• article
• page
• customer
• …
Đối tượng product
• product.available
• product.collections
• product.description
• product.featured_image
• product.alias
• product.id
• product.tags
• product.name
• product.type
• product.url
• product.vendor
• ...
Bộ lọc
• Bộ lọc dùng để sửa đổi kết quả được xuất ra của một số, chuỗi, biến
hoặc đối tượng.
• Chúng được đặt trong {{ }}, có thể dùng nhiều bộ lọc cùng lúc, khi đó
chúng được phân cách bởi |
{{ "normalize.css" | asset_url }}
Output:
//bizweb.dktcdn.net/100/043/252/themes/55930/assets/normalize.css
{{ "normalize.css" | asset_url | stylesheet_tag }}
Output:
<link href='//bizweb.dktcdn.net/100/043/252/themes/55930/assets/normalize.css'
rel='stylesheet' type='text/css' />
Các loại bộ lọc
• Bộ lọc mảng:
join, first, last, index, map, size, sort
• Bộ lọc HTML
img_tag, script_tag, stylesheet_tag
• Bộ lọc toán học
ceil, divided_by, floor, minus,…
• Bộ lọc tiền tệ
money, money_with_currency, money_without_currency,…
• Bộ lọc chuỗi
append, camelcase, capitalize, downcase,…
• Bộ lọc ULR
asset_url, img_url, link_to_tag,…
• Các bộ lọc khác
date, hightlight,…
Cấu trúc giao diện Bizweb
• assets: bao gồm các file thư viện sẽ được sử dụng cho giao diện
như ảnh, file css, và các file js
• configs: gồm 2 tập tin settings_schema.json và settings_data.json
• layouts: bao gồm các file khung giao diện, mặc định sẽ có
theme.bwt
• snippets: gồm các đoạn mã ngắn (snippet) mà giao diện có thể
dùng lại nhiều lần khi cần
• templates: bao gồm các template của giao diện
Cấu trúc giao diện của Bizweb
Layouts (File giao diện chính)
• theme.bwt (header, navigation and
footer)
Templates (file giao diện trang chức năng)
• index.bwt (trang chủ)
• product.bwt (trang sản phẩm)
• blog.bwt (trang blog)
• page.bwt (trang nội dung)
• …
Snippets (Những mẩu code để tái sử dụng trong
theme)
Assets (images, stylesheets, javascript)
Configs (file cấu hình cho theme)
Locales (chứa file ngôn ngữ của theme)
Hệ thống giao diện Bizweb
• Khung giao diện (layout)
• Các template cơ bản
• Thiết lập giao diện
Khung giao diện là gì?
• Khung giao diện là một thành phần rất quan trọng của giao diện.
• Các thành phần của website sẽ hiển thị thông qua khung giao diện đang
được kích hoạt.
• Chỉ có một khung giao diện được sử dụng mỗi khi hiển thị trang web.
theme.bwt
• Khung giao diện chính, mặc định cho mỗi giao
diện.
• Các template sẽ được hiển thị thông qua
khung giao diện này.
• Các thành phần xuất hiện lặp đi lặp lại ở tất
cả các trang nên được đặt trong theme.bwt.
Ví dụ: logo, menu đầu trang, phần chân trang
Template
• Hệ thống giao diện Bizweb được tạo nên bởi
các file template Liquid.
• Mỗi file template có cách sử dụng khác nhau
tùy vào nội dung nó được quy định để hiển
thị.
• Các file template:
• index.bwt
• collection.bwt
• product.bwt
• blog.bwt
• …
index.bwt
Hiển thị nội dung trang chủ của website.
Nội dung có thể gồm:
• Giới thiệu website
• Một danh sách sản phẩm
• Sản phẩm tiêu biểu
• …
collection.bwt
Hiển thị nội dung trang danh mục sản phẩm
của website.
Nội dung có thể gồm:
• Mô tả về danh mục sản phẩm
• Danh sách các sản phẩm trong danh
mục
• Một danh sách sản phẩm tiêu biểu
• …
product.bwt
Hiển thị nội dung chi tiết của sản phẩm trên
website.
Nội dung có thể gồm:
• Tên sản phẩm
• Ảnh sản phẩm
• Mô tả chi tiết của sản phẩm
• …
page.bwt
Hiển thị nội dung của một trang.
Nội dung có thể gồm:
• Tiêu đề trang
• Nội dung của trang
• Banner quảng cáo
• …
Thiết lập giao diện
Thiết lập giao diện
• Người phát triển giao diện có thể dễ dàng thêm vào các tuỳ chọn để
người sử dụng có thể tuỳ biến các thành phần của giao diện mà
không cần biết hay tìm hiểu về Liquid.
• Khả năng tuỳ biến đem lại sự tiện lợi cho người dùng, cũng như tạo
nên điểm nổi trội của giao diện.
• Thông qua thiết lập giao diện, người sử dụng giao diện có thể:
• Kích hoạt ẩn/hiện một khu vực, đối tượng trên giao diện như
banner, slideshow, hiển thị danh sách sản phẩm,…
• Thay đổi nội dung của một đối tượng như thay đổi ảnh banner,
thay đổi danh mục sản phẩm sẽ hiển thị tại một khu vực,…
End.
Tạo trang index cơ bản với Bizweb
Giao diện trang chủ cơ bản
Phần đầu trang:
• logo
• menu điều hướng
Phần nội dung chính:
• đoạn văn bản ngắn giới thiệu
• một danh sách các sản phẩm tiêu biểu
Phần chân trang:
• Menu điều hướng phụ
theme.bwt
Phần đầu trang:
• logo
• menu điều hướng
Phần chân trang:
• Menu điều hướng phụ
<!doctype html>
<html>
<head>
<meta charset="utf-8">
{{ content_for_header }}
</head>
<body>
{{ content_for_layout }}
</body>
</html>
<head>
<meta charset=“utf-8">
<title>{{ page_title }} - {{ store.name }}</title>
{{ content_for_header }}
{{ "normalize.css" | asset_url | stylesheet_tag }}
{{ "style.css" | asset_url | stylesheet_tag }}
{{ "common.js" | bizweb_asset_url | script_tag }}
{{ "customer.js" | bizweb_asset_url | script_tag }}
{{ '//ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.js' | script_tag }}
</head>
<head>
<body>
<div class="container">
<div class="content">
{{ content_for_layout }}
</div>
</div>
</body>
<body>
<body>
<div class="container">
<h1 class="logo"><a href="/">{{ store.name }}</a></h1>
<div class="content">
{{ content_for_layout }}
</div>
</div>
</body>
<body>
<div class="container">
<h1 class="logo"><a href="/">{{ store.name }}</a></h1>
<nav class="main-menu">
<ul>
{% for link in linklists.main-menu.links %}
<li {% if link.active %}class="current"{% endif %}>
<a href="{{ link.url }}">{{ link.title }}</a>
</li>
{% endfor %}
</ul>
</nav>
<div class="content">
{{ content_for_layout }}
</div>
</div>
Header menu
…
<div class="content">
{{ content_for_layout }}
</div>
<footer>
<ul>
{% for link in linklists.footer.links %}
<li><a href="{{ link.url }}">{{ link.title }}</a></li>
{% endfor %}
</ul>
</footer>
…
Footer menu
index.bwt
• Đoạn văn bản ngắn giới thiệu
• Danh sách các sản phẩm
Hiển thị nội dung có sẵn từ trang nội dung
Lấy dữ liệu từ trang “Giới thiệu”
<div class="rte index-page">
<h2>{{ pages.gioi-thieu.title }}</h2>
{{ pages.gioi-thieu.content }}
</div>
Hiển thị danh sách sản phẩm
Sử dụng snippet
• Ảnh sản phẩm
• Tên sản phẩm
• Giá bán
<div class="product left {% cycle '','','','last' %}">
<div class="product-thumb">
<a href="{{ product.url }}">
<img src="{{ product.featured_image.src | img_url: 'medium' }}" alt="{{
product.featured_image.alt }}" />
</a>
</div>
<div class="product-title">
<a href="{{ product.url }}">
{{ product.name }}
</a>
</div>
<div class="product-price">
{% if product.price_varies %}Giá từ{% endif %}
{{ product.price | money }}
</div>
</div>
<div class="clearfix">
<h2>Sản phẩm mới</h2>
<div class="collection-desc rte">
{{ collections.trang-chu.description }}
</div>
{% for product in collections.trang-chu.products %}
{% include 'product-loop' %}
{% endfor %}
</div>
<div class="clearfix">
<h2>Sản phẩm mới</h2>
<div class="collection-desc rte">
{{ collections.trang-chu.description }}
</div>
{% for product in collections.trang-chu.products limit:8 %}
{% include 'product-loop' %}
{% endfor %}
</div>
Bizweb theme workshop

More Related Content

What's hot

ASP.NET OverView
ASP.NET OverViewASP.NET OverView
ASP.NET OverViewNăm Tàn
 
Bài 1: Làm quen với ASP.NET - Giáo trình FPT - Có ví dụ kèm theo
Bài 1: Làm quen với ASP.NET - Giáo trình FPT - Có ví dụ kèm theoBài 1: Làm quen với ASP.NET - Giáo trình FPT - Có ví dụ kèm theo
Bài 1: Làm quen với ASP.NET - Giáo trình FPT - Có ví dụ kèm theoMasterCode.vn
 
Giáo trình thiết kế web - Thiết kế web với Dreamweaver
Giáo trình thiết kế web - Thiết kế web với DreamweaverGiáo trình thiết kế web - Thiết kế web với Dreamweaver
Giáo trình thiết kế web - Thiết kế web với DreamweaverKhanhPham
 
Slide 2 - Thiết kế Web cơ bản
Slide 2 - Thiết kế Web cơ bảnSlide 2 - Thiết kế Web cơ bản
Slide 2 - Thiết kế Web cơ bảnSống Khác
 
Tu hoc microsoft asp.net
Tu hoc microsoft asp.netTu hoc microsoft asp.net
Tu hoc microsoft asp.netnamhh1984ag
 
Bài 2 Cơ chế làm việc của CSS - Giáo trình FPT
Bài 2 Cơ chế làm việc của CSS - Giáo trình FPTBài 2 Cơ chế làm việc của CSS - Giáo trình FPT
Bài 2 Cơ chế làm việc của CSS - Giáo trình FPTMasterCode.vn
 
Bài 5 Bố cục trang cơ bản - Giáo trình FPT
Bài 5 Bố cục trang cơ bản - Giáo trình FPTBài 5 Bố cục trang cơ bản - Giáo trình FPT
Bài 5 Bố cục trang cơ bản - Giáo trình FPTMasterCode.vn
 
BÀI 3 Bố cục trang web & bảng (TABLE) trên trang web - Giáo trình FPT
BÀI 3 Bố cục trang web & bảng (TABLE) trên trang web - Giáo trình FPTBÀI 3 Bố cục trang web & bảng (TABLE) trên trang web - Giáo trình FPT
BÀI 3 Bố cục trang web & bảng (TABLE) trên trang web - Giáo trình FPTMasterCode.vn
 
Bài 6 Thiết kế các thành phần giao diện - Giáo trình FPT
Bài 6 Thiết kế các thành phần giao diện - Giáo trình FPTBài 6 Thiết kế các thành phần giao diện - Giáo trình FPT
Bài 6 Thiết kế các thành phần giao diện - Giáo trình FPTMasterCode.vn
 
Bài 7: Thư viện jQuery và thư viện jQuery UI - Giáo trình FPT
Bài 7: Thư viện jQuery và thư viện jQuery UI - Giáo trình FPTBài 7: Thư viện jQuery và thư viện jQuery UI - Giáo trình FPT
Bài 7: Thư viện jQuery và thư viện jQuery UI - Giáo trình FPTMasterCode.vn
 
Slide 5 - Thiết kế Web cơ bản
Slide 5 - Thiết kế Web cơ bảnSlide 5 - Thiết kế Web cơ bản
Slide 5 - Thiết kế Web cơ bảnSống Khác
 
BÀI 6 Làm việc với thành phần FORM, SPRY trong DREAMWEAVER CS4 - Giáo trình FPT
BÀI 6 Làm việc với thành phần FORM, SPRY trong DREAMWEAVER CS4 - Giáo trình FPTBÀI 6 Làm việc với thành phần FORM, SPRY trong DREAMWEAVER CS4 - Giáo trình FPT
BÀI 6 Làm việc với thành phần FORM, SPRY trong DREAMWEAVER CS4 - Giáo trình FPTMasterCode.vn
 

What's hot (16)

ASP.NET OverView
ASP.NET OverViewASP.NET OverView
ASP.NET OverView
 
Bài 1: Làm quen với ASP.NET - Giáo trình FPT - Có ví dụ kèm theo
Bài 1: Làm quen với ASP.NET - Giáo trình FPT - Có ví dụ kèm theoBài 1: Làm quen với ASP.NET - Giáo trình FPT - Có ví dụ kèm theo
Bài 1: Làm quen với ASP.NET - Giáo trình FPT - Có ví dụ kèm theo
 
Lap trinh asp.net
Lap trinh asp.netLap trinh asp.net
Lap trinh asp.net
 
Html full
Html fullHtml full
Html full
 
Slide5
Slide5Slide5
Slide5
 
Giáo trình thiết kế web - Thiết kế web với Dreamweaver
Giáo trình thiết kế web - Thiết kế web với DreamweaverGiáo trình thiết kế web - Thiết kế web với Dreamweaver
Giáo trình thiết kế web - Thiết kế web với Dreamweaver
 
Slide 2 - Thiết kế Web cơ bản
Slide 2 - Thiết kế Web cơ bảnSlide 2 - Thiết kế Web cơ bản
Slide 2 - Thiết kế Web cơ bản
 
Tu hoc microsoft asp.net
Tu hoc microsoft asp.netTu hoc microsoft asp.net
Tu hoc microsoft asp.net
 
Bài 2 Cơ chế làm việc của CSS - Giáo trình FPT
Bài 2 Cơ chế làm việc của CSS - Giáo trình FPTBài 2 Cơ chế làm việc của CSS - Giáo trình FPT
Bài 2 Cơ chế làm việc của CSS - Giáo trình FPT
 
Bài 5 Bố cục trang cơ bản - Giáo trình FPT
Bài 5 Bố cục trang cơ bản - Giáo trình FPTBài 5 Bố cục trang cơ bản - Giáo trình FPT
Bài 5 Bố cục trang cơ bản - Giáo trình FPT
 
BÀI 3 Bố cục trang web & bảng (TABLE) trên trang web - Giáo trình FPT
BÀI 3 Bố cục trang web & bảng (TABLE) trên trang web - Giáo trình FPTBÀI 3 Bố cục trang web & bảng (TABLE) trên trang web - Giáo trình FPT
BÀI 3 Bố cục trang web & bảng (TABLE) trên trang web - Giáo trình FPT
 
Bài 6 Thiết kế các thành phần giao diện - Giáo trình FPT
Bài 6 Thiết kế các thành phần giao diện - Giáo trình FPTBài 6 Thiết kế các thành phần giao diện - Giáo trình FPT
Bài 6 Thiết kế các thành phần giao diện - Giáo trình FPT
 
Bài 7: Thư viện jQuery và thư viện jQuery UI - Giáo trình FPT
Bài 7: Thư viện jQuery và thư viện jQuery UI - Giáo trình FPTBài 7: Thư viện jQuery và thư viện jQuery UI - Giáo trình FPT
Bài 7: Thư viện jQuery và thư viện jQuery UI - Giáo trình FPT
 
Slide 5 - Thiết kế Web cơ bản
Slide 5 - Thiết kế Web cơ bảnSlide 5 - Thiết kế Web cơ bản
Slide 5 - Thiết kế Web cơ bản
 
Tài liệu HTML5-CSS3
Tài liệu HTML5-CSS3Tài liệu HTML5-CSS3
Tài liệu HTML5-CSS3
 
BÀI 6 Làm việc với thành phần FORM, SPRY trong DREAMWEAVER CS4 - Giáo trình FPT
BÀI 6 Làm việc với thành phần FORM, SPRY trong DREAMWEAVER CS4 - Giáo trình FPTBÀI 6 Làm việc với thành phần FORM, SPRY trong DREAMWEAVER CS4 - Giáo trình FPT
BÀI 6 Làm việc với thành phần FORM, SPRY trong DREAMWEAVER CS4 - Giáo trình FPT
 

Similar to Bizweb theme workshop

Thiết kế giao diện với Liquid
Thiết kế giao diện với LiquidThiết kế giao diện với Liquid
Thiết kế giao diện với LiquidTien Nguyen
 
Web1012 slide 1
Web1012   slide 1Web1012   slide 1
Web1012 slide 1Cà Rốt
 
Pd fbuoi2 onpage – tối ưu hóa trang web-mastercode.vn
Pd fbuoi2 onpage – tối ưu hóa trang web-mastercode.vnPd fbuoi2 onpage – tối ưu hóa trang web-mastercode.vn
Pd fbuoi2 onpage – tối ưu hóa trang web-mastercode.vnMasterCode.vn
 
BÀI 5 Tối ưu hóa thiết kế web và cách làm việc cơ bản trong chế độ hiển thị C...
BÀI 5 Tối ưu hóa thiết kế web và cách làm việc cơ bản trong chế độ hiển thị C...BÀI 5 Tối ưu hóa thiết kế web và cách làm việc cơ bản trong chế độ hiển thị C...
BÀI 5 Tối ưu hóa thiết kế web và cách làm việc cơ bản trong chế độ hiển thị C...MasterCode.vn
 
Slide2 - Co ban HTML5
Slide2 - Co ban HTML5Slide2 - Co ban HTML5
Slide2 - Co ban HTML5Đặng Til
 
Chủ đề 9 wordpress - vũ mạnh cường
Chủ đề 9  wordpress - vũ mạnh cườngChủ đề 9  wordpress - vũ mạnh cường
Chủ đề 9 wordpress - vũ mạnh cườngVũ Mạnh Cường
 
Html coban
Html coban Html coban
Html coban Cá Cơm
 
Kiến thức cần thiết làm việc
Kiến thức cần thiết làm việcKiến thức cần thiết làm việc
Kiến thức cần thiết làm việcmanhvokiem
 
Lập trình web - HTML cơ bản
Lập trình web - HTML cơ bảnLập trình web - HTML cơ bản
Lập trình web - HTML cơ bảnNhóc Nhóc
 
Lập trình web – cgi
Lập trình web – cgiLập trình web – cgi
Lập trình web – cgiSon Nguyen
 
Alfresco hệ quản lý nội dung doanh nghiệp nguồn mở
Alfresco   hệ quản lý nội dung doanh nghiệp nguồn mởAlfresco   hệ quản lý nội dung doanh nghiệp nguồn mở
Alfresco hệ quản lý nội dung doanh nghiệp nguồn mởHọc Huỳnh Bá
 
Bài 2: Web Part và các trang SharePoint
Bài 2: Web Part và các trang SharePointBài 2: Web Part và các trang SharePoint
Bài 2: Web Part và các trang SharePointMasterCode.vn
 
Tuan5 dreamweaver 0001
Tuan5 dreamweaver 0001Tuan5 dreamweaver 0001
Tuan5 dreamweaver 0001Chu Kien
 
Php day 2011 - Nukeviet
Php day 2011 -  NukevietPhp day 2011 -  Nukeviet
Php day 2011 - NukevietQuang Anh Le
 
Thuong mai dien tu v2.0 bach
Thuong mai dien tu v2.0   bachThuong mai dien tu v2.0   bach
Thuong mai dien tu v2.0 bachBach Phan
 

Similar to Bizweb theme workshop (20)

Thiết kế giao diện với Liquid
Thiết kế giao diện với LiquidThiết kế giao diện với Liquid
Thiết kế giao diện với Liquid
 
Web1012 slide 1
Web1012   slide 1Web1012   slide 1
Web1012 slide 1
 
Pd fbuoi2 onpage – tối ưu hóa trang web-mastercode.vn
Pd fbuoi2 onpage – tối ưu hóa trang web-mastercode.vnPd fbuoi2 onpage – tối ưu hóa trang web-mastercode.vn
Pd fbuoi2 onpage – tối ưu hóa trang web-mastercode.vn
 
BÀI 5 Tối ưu hóa thiết kế web và cách làm việc cơ bản trong chế độ hiển thị C...
BÀI 5 Tối ưu hóa thiết kế web và cách làm việc cơ bản trong chế độ hiển thị C...BÀI 5 Tối ưu hóa thiết kế web và cách làm việc cơ bản trong chế độ hiển thị C...
BÀI 5 Tối ưu hóa thiết kế web và cách làm việc cơ bản trong chế độ hiển thị C...
 
Slide2
Slide2Slide2
Slide2
 
Slide2 - Co ban HTML5
Slide2 - Co ban HTML5Slide2 - Co ban HTML5
Slide2 - Co ban HTML5
 
Chủ đề 9 wordpress - vũ mạnh cường
Chủ đề 9  wordpress - vũ mạnh cườngChủ đề 9  wordpress - vũ mạnh cường
Chủ đề 9 wordpress - vũ mạnh cường
 
Thutap
ThutapThutap
Thutap
 
Html coban
Html coban Html coban
Html coban
 
Kiến thức cần thiết làm việc
Kiến thức cần thiết làm việcKiến thức cần thiết làm việc
Kiến thức cần thiết làm việc
 
Lập trình web - HTML cơ bản
Lập trình web - HTML cơ bảnLập trình web - HTML cơ bản
Lập trình web - HTML cơ bản
 
Lập trình web – cgi
Lập trình web – cgiLập trình web – cgi
Lập trình web – cgi
 
Alfresco hệ quản lý nội dung doanh nghiệp nguồn mở
Alfresco   hệ quản lý nội dung doanh nghiệp nguồn mởAlfresco   hệ quản lý nội dung doanh nghiệp nguồn mở
Alfresco hệ quản lý nội dung doanh nghiệp nguồn mở
 
Bài giảng HTML5-CSS3
Bài giảng HTML5-CSS3Bài giảng HTML5-CSS3
Bài giảng HTML5-CSS3
 
Bài 2: Web Part và các trang SharePoint
Bài 2: Web Part và các trang SharePointBài 2: Web Part và các trang SharePoint
Bài 2: Web Part và các trang SharePoint
 
Tuan5 dreamweaver 0001
Tuan5 dreamweaver 0001Tuan5 dreamweaver 0001
Tuan5 dreamweaver 0001
 
PHP
PHPPHP
PHP
 
Joomla developermanual
Joomla developermanualJoomla developermanual
Joomla developermanual
 
Php day 2011 - Nukeviet
Php day 2011 -  NukevietPhp day 2011 -  Nukeviet
Php day 2011 - Nukeviet
 
Thuong mai dien tu v2.0 bach
Thuong mai dien tu v2.0   bachThuong mai dien tu v2.0   bach
Thuong mai dien tu v2.0 bach
 

Bizweb theme workshop

  • 1. Thiết kế giao diện với Liquid Bizweb - 26/12/2015
  • 2. Liquid là gì? • Ngôn ngữ lập trình giao diện được phát triển bởi Shopify • Mã nguồn mở, phát triển từ năm 2006 • Sử dụng để frontend có thể truy cập và lấy dữ liệu từ backend một cách an toàn và dễ dàng.
  • 4. Các hệ thống đang sử dụng
  • 5. Ưu điểm của Liquid • Cấu trúc đơn giản, dễ nhớ, dễ sử dụng, thân thiện với Designer • Bảo mật code trên server của bạn • Kết hợp dễ dàng với cấu trúc HTML có sẵn. • Người dùng có thể tự tùy biến giao diện hiển thị mà không cần quan tâm đến backend. • Tương đồng với Smarty, Twig
  • 6. Liquid cơ bản • Các toán tử (Operators) • Kiểu dữ liệu (Types) • Thẻ (Tags) • Đối tượng (Objects) • Bộ lọc (Filters)
  • 7. Các toán tử Liquid hỗ trợ các toán tử logic, so sánh và toán tử bao hàm. == bằng != không bằng > lớn hơn < nhỏ hơn >= lớn hơn hoặc bằng <= nhỏ hơn hoặc bằng or điều kiện A hoặc điều kiện B and điều kiện A và điều kiện B contains kiểm tra xem có sự xuất hiện của một chuỗi
  • 8. {% if product.name == "Giày Converse" %} Đây là đôi giày Converse {% endif %} {% if product.name contains 'Converse' %} Đây là một sản phẩm của Converse {% endif %}
  • 9. Kiểu dữ liệu Liquid hỗ trợ các kiểu dữ liệu cơ bản như: • Chuỗi • Số • Boolean • Mảng Và ‘nil/null’ một giá trị rỗng được trả về khi thực thi một đoạn mã Liquid mà không thể cho ra kết quả
  • 10. Thẻ Liquid sử dụng các thẻ logic để thông báo cho hệ thống cần trả về dữ liệu là gì, các thẻ được bao bởi {% và %} Thẻ điều khiển luồng Thẻ lặp Thẻ giao diện Thẻ liên quan đến biến if for comment assign elseif / else cycle include capture case/when form increment unless layout decrement paginate raw
  • 11. <!-- Nếu customer.name = 'guest' --> {% if customer.name == 'Gyo' %} Chào bạn Gyo! {% elsif customer.name == 'guest' %} Xin chào quý khách! {% else %} Chào bạn! {% endif %}
  • 12. Đối tượng Các đối tượng trong Liquid bao gồm các thuộc tính để xuất ra nội dung động tương ứng, khi gọi các thuộc tính theo đối tượng tương ứng, sử dụng {{ và }} để bao ngoài (ví dụ: {{ product.name }} ). Các đối tượng tiêu biểu: • collection • product • cart • blog • article • page • customer • …
  • 13. Đối tượng product • product.available • product.collections • product.description • product.featured_image • product.alias • product.id • product.tags • product.name • product.type • product.url • product.vendor • ...
  • 14. Bộ lọc • Bộ lọc dùng để sửa đổi kết quả được xuất ra của một số, chuỗi, biến hoặc đối tượng. • Chúng được đặt trong {{ }}, có thể dùng nhiều bộ lọc cùng lúc, khi đó chúng được phân cách bởi |
  • 15. {{ "normalize.css" | asset_url }} Output: //bizweb.dktcdn.net/100/043/252/themes/55930/assets/normalize.css {{ "normalize.css" | asset_url | stylesheet_tag }} Output: <link href='//bizweb.dktcdn.net/100/043/252/themes/55930/assets/normalize.css' rel='stylesheet' type='text/css' />
  • 16. Các loại bộ lọc • Bộ lọc mảng: join, first, last, index, map, size, sort • Bộ lọc HTML img_tag, script_tag, stylesheet_tag • Bộ lọc toán học ceil, divided_by, floor, minus,… • Bộ lọc tiền tệ money, money_with_currency, money_without_currency,… • Bộ lọc chuỗi append, camelcase, capitalize, downcase,… • Bộ lọc ULR asset_url, img_url, link_to_tag,… • Các bộ lọc khác date, hightlight,…
  • 17. Cấu trúc giao diện Bizweb • assets: bao gồm các file thư viện sẽ được sử dụng cho giao diện như ảnh, file css, và các file js • configs: gồm 2 tập tin settings_schema.json và settings_data.json • layouts: bao gồm các file khung giao diện, mặc định sẽ có theme.bwt • snippets: gồm các đoạn mã ngắn (snippet) mà giao diện có thể dùng lại nhiều lần khi cần • templates: bao gồm các template của giao diện
  • 18. Cấu trúc giao diện của Bizweb Layouts (File giao diện chính) • theme.bwt (header, navigation and footer) Templates (file giao diện trang chức năng) • index.bwt (trang chủ) • product.bwt (trang sản phẩm) • blog.bwt (trang blog) • page.bwt (trang nội dung) • … Snippets (Những mẩu code để tái sử dụng trong theme) Assets (images, stylesheets, javascript) Configs (file cấu hình cho theme) Locales (chứa file ngôn ngữ của theme)
  • 19. Hệ thống giao diện Bizweb • Khung giao diện (layout) • Các template cơ bản • Thiết lập giao diện
  • 20. Khung giao diện là gì? • Khung giao diện là một thành phần rất quan trọng của giao diện. • Các thành phần của website sẽ hiển thị thông qua khung giao diện đang được kích hoạt. • Chỉ có một khung giao diện được sử dụng mỗi khi hiển thị trang web.
  • 21. theme.bwt • Khung giao diện chính, mặc định cho mỗi giao diện. • Các template sẽ được hiển thị thông qua khung giao diện này. • Các thành phần xuất hiện lặp đi lặp lại ở tất cả các trang nên được đặt trong theme.bwt. Ví dụ: logo, menu đầu trang, phần chân trang
  • 22. Template • Hệ thống giao diện Bizweb được tạo nên bởi các file template Liquid. • Mỗi file template có cách sử dụng khác nhau tùy vào nội dung nó được quy định để hiển thị. • Các file template: • index.bwt • collection.bwt • product.bwt • blog.bwt • …
  • 23. index.bwt Hiển thị nội dung trang chủ của website. Nội dung có thể gồm: • Giới thiệu website • Một danh sách sản phẩm • Sản phẩm tiêu biểu • …
  • 24. collection.bwt Hiển thị nội dung trang danh mục sản phẩm của website. Nội dung có thể gồm: • Mô tả về danh mục sản phẩm • Danh sách các sản phẩm trong danh mục • Một danh sách sản phẩm tiêu biểu • …
  • 25. product.bwt Hiển thị nội dung chi tiết của sản phẩm trên website. Nội dung có thể gồm: • Tên sản phẩm • Ảnh sản phẩm • Mô tả chi tiết của sản phẩm • …
  • 26. page.bwt Hiển thị nội dung của một trang. Nội dung có thể gồm: • Tiêu đề trang • Nội dung của trang • Banner quảng cáo • …
  • 28. Thiết lập giao diện • Người phát triển giao diện có thể dễ dàng thêm vào các tuỳ chọn để người sử dụng có thể tuỳ biến các thành phần của giao diện mà không cần biết hay tìm hiểu về Liquid. • Khả năng tuỳ biến đem lại sự tiện lợi cho người dùng, cũng như tạo nên điểm nổi trội của giao diện. • Thông qua thiết lập giao diện, người sử dụng giao diện có thể: • Kích hoạt ẩn/hiện một khu vực, đối tượng trên giao diện như banner, slideshow, hiển thị danh sách sản phẩm,… • Thay đổi nội dung của một đối tượng như thay đổi ảnh banner, thay đổi danh mục sản phẩm sẽ hiển thị tại một khu vực,…
  • 29. End.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34. Tạo trang index cơ bản với Bizweb
  • 35. Giao diện trang chủ cơ bản Phần đầu trang: • logo • menu điều hướng Phần nội dung chính: • đoạn văn bản ngắn giới thiệu • một danh sách các sản phẩm tiêu biểu Phần chân trang: • Menu điều hướng phụ
  • 36. theme.bwt Phần đầu trang: • logo • menu điều hướng Phần chân trang: • Menu điều hướng phụ
  • 37. <!doctype html> <html> <head> <meta charset="utf-8"> {{ content_for_header }} </head> <body> {{ content_for_layout }} </body> </html>
  • 38. <head> <meta charset=“utf-8"> <title>{{ page_title }} - {{ store.name }}</title> {{ content_for_header }} {{ "normalize.css" | asset_url | stylesheet_tag }} {{ "style.css" | asset_url | stylesheet_tag }} {{ "common.js" | bizweb_asset_url | script_tag }} {{ "customer.js" | bizweb_asset_url | script_tag }} {{ '//ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.js' | script_tag }} </head> <head>
  • 39. <body> <div class="container"> <div class="content"> {{ content_for_layout }} </div> </div> </body> <body>
  • 40. <body> <div class="container"> <h1 class="logo"><a href="/">{{ store.name }}</a></h1> <div class="content"> {{ content_for_layout }} </div> </div> </body> <body>
  • 41. <div class="container"> <h1 class="logo"><a href="/">{{ store.name }}</a></h1> <nav class="main-menu"> <ul> {% for link in linklists.main-menu.links %} <li {% if link.active %}class="current"{% endif %}> <a href="{{ link.url }}">{{ link.title }}</a> </li> {% endfor %} </ul> </nav> <div class="content"> {{ content_for_layout }} </div> </div> Header menu
  • 42. … <div class="content"> {{ content_for_layout }} </div> <footer> <ul> {% for link in linklists.footer.links %} <li><a href="{{ link.url }}">{{ link.title }}</a></li> {% endfor %} </ul> </footer> … Footer menu
  • 43.
  • 44. index.bwt • Đoạn văn bản ngắn giới thiệu • Danh sách các sản phẩm
  • 45. Hiển thị nội dung có sẵn từ trang nội dung Lấy dữ liệu từ trang “Giới thiệu”
  • 46.
  • 47. <div class="rte index-page"> <h2>{{ pages.gioi-thieu.title }}</h2> {{ pages.gioi-thieu.content }} </div>
  • 48.
  • 49. Hiển thị danh sách sản phẩm
  • 50. Sử dụng snippet • Ảnh sản phẩm • Tên sản phẩm • Giá bán
  • 51.
  • 52. <div class="product left {% cycle '','','','last' %}"> <div class="product-thumb"> <a href="{{ product.url }}"> <img src="{{ product.featured_image.src | img_url: 'medium' }}" alt="{{ product.featured_image.alt }}" /> </a> </div> <div class="product-title"> <a href="{{ product.url }}"> {{ product.name }} </a> </div> <div class="product-price"> {% if product.price_varies %}Giá từ{% endif %} {{ product.price | money }} </div> </div>
  • 53. <div class="clearfix"> <h2>Sản phẩm mới</h2> <div class="collection-desc rte"> {{ collections.trang-chu.description }} </div> {% for product in collections.trang-chu.products %} {% include 'product-loop' %} {% endfor %} </div>
  • 54.
  • 55. <div class="clearfix"> <h2>Sản phẩm mới</h2> <div class="collection-desc rte"> {{ collections.trang-chu.description }} </div> {% for product in collections.trang-chu.products limit:8 %} {% include 'product-loop' %} {% endfor %} </div>