Để đơn giản cho các bạn sử dụng cũng như cho mình viết bài hướng dẫn, nên mình đã quyết định ngồi code lại cái menu này. Vẫn lấy phong cách của Zing, nhưng code thì mình viết lại hoàn toàn.
Ưu điểm của Mega Dropdown này là nó chỉ dùng CSS, nên khá nhẹ, và 1 cái nữa là phần dropdown các bạn có thể tùy biến nhiều thứ trong đó, chứ không đơn thuần chỉ hiện các liên kết con. Bởi thế nó mới được gọi là Mega Menu. Và nhược điểm của menu này là không hiển thị được submenu trên IE6. Thật ra nhược điểm này không phải là nhược điểm của thủ thuật mà là của chính blogger, hình như blogger nó không hỗ trợ file htc. Ngay cả host demo của mình cũng không chạy được, nhưng mình test offline trên máy tính thì rất ok.
Vì thế nếu bạn nào muốn dùng cái menu này thì sẽ phải chấp nhận việc nó không sổ submenu trên IE6. Còn từ IE7 trở nên thì vẫn chạy bình thường.
Các bạn có thể xem DEMO ở đây.
A. Sau đây là code của thủ thuật:
- Có 2 cách để thêm vào blog, 1 là các bạn chèn tất cả code của nó vào 1 widget HTML/javascript, 2 là các bạn chỉ chèn code HTML vào widget HTML/javascript, còn code CSS thì các bạn có thể add vào template, ngay trước dòng code </head>
- và đây là code của thủ thuật:
Code CSS:
#fdmega-menu ul {list-style: none;}
ul#topnav {
float: left;
width: 650px;
position: relative;
height: 39px;
background: #0082ff;
}
ul#topnav li {
float: left;
height: 39px;
padding: 0px;
background: url(http://data.fandung.com/blog/demo/Mega-Dropdown-MenuCSS/img/right-li-nobg.png) no-repeat top right;
}
ul#topnav li a {
padding: 10px 15px;
display: block;
color: #f0f0f0;
text-decoration: none;
}
ul#topnav li:hover {
background: #ff7d00 url(http://data.fandung.com/blog/demo/Mega-Dropdown-MenuCSS/img/top-li-hv.png) repeat-x top left;
}
ul#topnav li.mg-home {
background:url(http://data.fandung.com/blog/demo/Mega-Dropdown-MenuCSS/img/home-ico-bg.png) no-repeat top right!important;
width:45px;
}
ul#topnav li.mg-home a {height:19px;}
ul#topnav li div.sub {
position: absolute;
top: 39px;
background: #ff7d00;
padding:5px;
display: none;
border-right:4px solid #0082ff;
border-left:4px solid #0082ff;
border-bottom:4px solid #0082ff;
color:#fff;
}
ul#topnav li:hover div.sub {display: block;}
ul#topnav li div.sub p {margin-bottom:5px;text-align:justify;}
ul#topnav li div.sub div.cont {float: left;padding:5px;}
ul#topnav li div.sub div.cont h3 {}
ul#topnav li div.sub div.cont a{display:block; margin:0;padding:0;padding:0 0 5px;color:#ddd;}
ul#topnav li div.sub div.cont a:hover{color:#fff;}
ul#topnav li div.ms1 {}
ul#topnav li div.ms2 {width:300px;left: 118px;}
ul#topnav li div.ms3 {width:260px;left: 195px;}
ul#topnav li div.ms4 {}
ul#topnav li div.ms5 {width:400px;left: 16px;background:#ff7d00 url(sub6-bg.png) no-repeat bottom right;}
ul#topnav li div.sub div.cs21 {width:90px;}
ul#topnav li div.sub div.cs31 {width:120px;}
</style>
Code HTML:
<ul id="topnav">
<li class="mg-home"><a href="#"></a></li>
<li><a href="#">Menu 1</a></li>
<li><a href="#">Menu 2</a>
<div class="sub ms2">
<div class="cont cs21">
<h3>Love</h3>
<a href="#">Sub 2.1</a>
<a href="#">Sub 2.2</a>
<a href="#">Sub 2.3</a>
</div>
<div class="cont cs21">
<h3>Film</h3>
<a href="#">Sub 2.1</a>
<a href="#">Sub 2.2</a>
<a href="#">Sub 2.3</a>
</div>
<div class="cont cs21">
<h3>Ebooks</h3>
<a href="#">Sub 2.1</a>
<a href="#">Sub 2.2</a>
<a href="#">Sub 2.3</a>
</div>
</div>
</li>
<li><a href="#">Menu 3</a>
<div class="sub ms3">
<div class="cont cs31">
<a href="#">Sub 3.1 (120px)</a>
<a href="#">Sub 3.2 (120px)</a>
<a href="#">Sub 3.3 (120px)</a>
</div>
<div class="cont cs31">
<a href="#">Sub 3.1 (120px)</a>
<a href="#">Sub 3.2 (120px)</a>
<a href="#">Sub 3.3 (120px)</a>
</div>
</div>
</li>
<li><a href="#">Menu 4</a></li>
<li><a href="#">Menu 5</a>
<div class="sub ms5">
<b>James Gallagher</b><br/>
<span style="font-size:90%"><i>Health reporter, BBC News</i></span>
<p>Are bean sprouts in the clear? The simple answer is no, even though the early test results have come back negative.</p>
<p>The most compelling evidence so far has not come from the microbiology lab, but traditional detective work. Officials were able to link the main outbreaks with bean sprouts from one farm in northern Germany.</p>
<p>They will wait for test results from the remaining 17 samples for final confirmation. However, the prospect remains that no trace of E. coli will ever be found, since any contaminated produce would have been farmed and on the shelves weeks ago.</p>
<span style="font-size:90%"><i>Trich BBC</i></span>
</div>
</li>
</ul>
</div>
B. Sau đây là 1 vài hướng dẫn chỉnh sửa code HTML cũng như CSS
- Sau khi chèn code vào, các bạn sẽ gặp trường hợp như thế này:
- Việc bị lệch này là do vị trí của menu chính và menu phụ không khớp với nhau. Không khớp với nhau có nhiều lý do, ví dụ bạn thay đổi tên menu, độ rộng của menu chính sẽ thay đổi, dẫn tới menu phụ bị lệch.
- Để chỉnh vị trí của menu phụ với menu chính các bạn xem code CSS bên dưới:
...
ul#topnav li div.ms1 {}
ul#topnav li div.ms2 {width:300px;left: 118px;}
ul#topnav li div.ms3 {width:260px;left: 195px;}
ul#topnav li div.ms4 {}
ul#topnav li div.ms5 {width:400px;left: 16px;background:#ff7d00 url(sub6-bg.png) no-repeat bottom right;}
...
...
- Các class này để tùy chỉnh vị trí, độ rộng , màu nền ... của các vùng hiển thị của submenu.
- Lệnh left:118px; (của class ms2) chính là lệnh để tùy chỉnh vị trí của submenu so với biên ngang bên trái của menu chính. Ví dụ như hình bên dưới :
- Sau khi điều chỉnh vị trí các submenu xong, ta sẽ đi vào phần tùy chỉnh nội dung bên trong của các submenu. Ở đây ta sẽ lấy ví dụ submenu 2.
- Đây là code HTML của nó :
...
<li><a href="#">Menu 2</a>
<div class="sub ms2">
<div class="cont cs21">
<h3>Love</h3>
<a href="#">Sub 2.1</a>
<a href="#">Sub 2.2</a>
<a href="#">Sub 2.3</a>
</div>
<div class="cont cs21">
<h3>Film</h3>
<a href="#">Sub 2.1</a>
<a href="#">Sub 2.2</a>
<a href="#">Sub 2.3</a>
</div>
<div class="cont cs21">
<h3>Ebooks</h3>
<a href="#">Sub 2.1</a>
<a href="#">Sub 2.2</a>
<a href="#">Sub 2.3</a>
</div>
</div>
</li>
...
...
- ta thấy trong code CSS có đoạn như thế này :
...
ul#topnav li div.sub div.cs21 {width:90px;}
ul#topnav li div.sub div.cs31 {width:120px;}
...
...
...
ul#topnav li div.sub div.cs11 {width:135px;}
ul#topnav li div.sub div.cs21 {width:90px;}
ul#topnav li div.sub div.cs31 {width:120px;}
ul#topnav li div.sub div.cs41 {width:80px;}
ul#topnav li div.sub div.cs51 {width:190px;}
...
...
...
ul#topnav li div.sub div.cs21 {width:135px;}
ul#topnav li div.sub div.cs22 {width:90px;}
ul#topnav li div.sub div.cs23 {width:120px;}
...
...
...
<li><a href="#">Menu 2</a>
<div class="sub ms2">
<div class="cont cs21">
<h3>Love</h3>
<a href="#">Sub 2.1</a>
<a href="#">Sub 2.2</a>
<a href="#">Sub 2.3</a>
</div>
<div class="cont cs22">
<h3>Film</h3>
<a href="#">Sub 2.1</a>
<a href="#">Sub 2.2</a>
<a href="#">Sub 2.3</a>
</div>
<div class="cont cs23">
<h3>Ebooks</h3>
<a href="#">Sub 2.1</a>
<a href="#">Sub 2.2</a>
<a href="#">Sub 2.3</a>
</div>
</div>
</li>
...
...
- Ngoài ra nếu các bạn muốn thêm hình nền riêng cho mỗi sub thì cũng có thể thêm vào, ví dụ như trong demo ta có hình nền của submenu5, và bên dưới là code CSS mà các bạn có thể tùy chỉnh để thêm hình nền vào:
...
ul#topnav li div.ms1 {}
ul#topnav li div.ms2 {width:300px;left: 118px;}
ul#topnav li div.ms3 {width:260px;left: 195px;}
ul#topnav li div.ms4 {}
ul#topnav li div.ms5 {width:400px;left: 16px;background:#ff7d00 url(sub6-bg.png) no-repeat bottom right;}
...
...
- các bạn thêm hình nền tương tự như class ms5 (của submenu5).
- Ở trên các class ms1 và ms4 mình để trống do các menu4 và menu1 trong demo không có submenu, khi có submenu thì các bạn thêm vào giá trị độ rộng và vị trí cách biên ngang cho các submenu này.
Hy vọng các bạn có thể thực hiện nó với các hướng dẫn cơ bản trên.
Menu mega dropdown này trước khi còn test offline, mình cảm thấy rất tâm đắc với nó, nhưng khi add vô rồi thì lại gặp sự cố là blogger không support file htc, nên cũng hơi nản. Thậm chí mình còn có ý định sẽ không post bài này. Nhưng rồi nghĩ lại cũng sẽ có 1 số người cần nó, và rồi cũng cố ngồi trước máy tính để soạn bài hướng dẫn này.
Chúc các bạn thành công.
Menu dropdown rất tiện ích nhưng áp dụng thì hơi phức tạp nhỉ. Với lại dropdown chèn vào blog của mình nhìn không được vừa vặn cho lắm, huhu!
thích hợp với các blog đa dạng category như của anh Dũng, nhìn rất hợp lí
Cái này hơi ngoài lề 1 tí : Anh dũng nhận dc email chưa, em gửi nó vào email YH của anh rồi
P/s:Cái mega này nhìn thấy cổ điển quá nhỉ?
Loại menu này chỉ hợp với Blog có nhiều category hoặc nội dung được phân thành nhiều thể loại, blog mình mà áp dụng cái này chắc điên mất ^^!
Mấy cái menu dạng này đẹp thật nhưng tùy blog mà dùng
bài viết rất công phu, thanks bác!
wow ! Tuyệt quá D ơi. ! chờ mãi mới được share bài này đó, phải test thử mới được. !ồ ze.
A ma Dũng ơi, D co biết làm một form liên hệ không zi, mình c tìm trên mạng rùi mà cái form nào cũng bằng lập trình PHP hít, mà m thì bó tay với PHP. Dũng có thể viết một bài về Contact mail không dùng mả capcha không ?
Ah, theo b tao menu guiong trang vnexpress thi dung co the doi mau cho menu duoc khong ? minh rat thich mau xanh giong trang http://www.phuongkhuongmai.gov.vn, lam hoai ma khong dc, chan.
rất hay, cám ơn FD nhiều
Cảm bác FD rất nhiều - bài viết rất hay và công phu - em luôn ủng hộ bác :D
Em ăn cắp cái Note của bác có sao ko bác Dũng ;))
mấy bữa nay đi làm về mệt quá, hôm qua chỉ kịp sửa lại cái feature post.
@Nguyễn Đức : cứ tự nhiên bạn, có điều nên chỉnh sửa lại code CSS để cho cái note nó tông/ tông với blog của bạn :D, cái này mình cũng lấy từ Blogger mà :D
@Ngân: cái propage hiện tại đúng là load hơi lâu, ko biết có phải do feed của blogger dạo này có vấn đề gì ko. bên mình cũng cảm thấy hơi lâu, đang cố gắng dẹp cho gọn lại.
- còn cái bài viết này thì đúng là cũng hơi lâu thiệt, nhưng phần làm ảnh chú thích cũng ko tới 3 hay 4 tiếng gì đâu Ngân :D, mình viết đến đâu chụp ảnh rồi chú thích đến đó, tính ra viết bài này cũng mất mấy tiếng đồng hồ :D
Nói thật Pro Blogspot hiện đang xuất hiện rất nhiều nhưng sao mình vẫn cứ thấy FD là cảm tình nhất.
Đúng đó - theo dự đoán Blogger năm 2011 và sắp các năm sắp tới ở việt nam sẽ dần dần nóng lên. và Fandung.com là 1 địa chỉ tin cậy cho chúng ta học về blogger. :)
Bài viết hay lắm bạn à :) thanks nhé :D
thấy mọi người ủng hộ như vậy, mình cảm thấy rất vui. Thanks tất cả.
Đã Test - Tình hình là trên Firefox thì không bị lệch. nhưng trên google chorm lại bị lệch. Mong bác sớm fix lỗi này.
Mình thấy dạng MENU này cũng hay, nhưng site của mình tương đối đơn giản nên không áp dụng.
Mình mới tạo blog http://www.truyenjava.co.cc/, Blog đang cần sự góp ý chân thành của bạn, rất vui được làm quen với bạn, nếu được chúng ta trao đổi links nhé:
http://www.truyenjava.co.cc/2011/06/tiep-nhan-add-link-va-lam-quen.html
Cho em thắc mắc cái ?
Sao em làm menu sổ xuống mà nó bị che núp đằng sau của một widget ở phía dưới?
Đáng ra nó phải nổi lên trên như blog FD chứ anh?
Cứu Với ?!!!
Hay quá trời lun pác Dũng ui.Pác pro thật.:)
Nguyễn Văn Hậu@ Mình cũng bị vậy luôn..Help với
hj anh Dũng e mới lập blog toàn làm theo thủ thuật của anh. phải nói anh rất pro em làm cái nào hầu như cũng thành công. nhưng cái mennu nào xổ xuống là blog em ko nhìn thấy dc( giống với nỗi của nhiều nguwoif ) chỉ thành công cái menu của vnexprees thôi. anh có thể kiểm tra xem em mắc nỗi j ko
có thể add YH em: neuemdaquenroi_hp1991
em lam duoc roi, cam on anh nhieu nha
Anh Dũng ơi.Em thấy cách anh làm hơi dài.em làm chỉ cần 1 đoan code dán vào javar/script là ok.;;)
hix em làm đc nhưng mà nó bị chìm dưới các cái khác anh ạ chả hiểu sao nữa
blog của anh Dũng rất hay.rất vui khi mọi người ghé thăm http://www.vuhuong.com/
LÀm thì làm đc nhưng khi sổ xuống là bị chìm trong Bài viết hoặc Widget khác anh ak! Fix sao đây anh! :((
mình cũng bị tương tự giống bạn, xổ xuống thì lại nằm dưới 1 cái gì đó, giờ muốn cho nằm trên thì sao, chỉ mình với ^^!
Đúng oy,A Fan Dũng ơi,nó bị widget che mất phần sub :(( a test giùm và fix giúp mọi người với:((
Chuẩn lắm :)
Ang Dũng ơi sao em chèn vào Blog rồi mà lúc di chuột vào chả thấy nó sổ xuống là sao?
Thanks FD sẽ áp dụng vào Blog của mình.
@All: Ai bị widget che mất phần sub, thì kiếm đoạn
ul#topnav li div.sub {
trong CSS, rồi thêm dòng
z-index:10;
nhé ^^!
làm thì được đó anh Dũng ak
Chỉ có tội là nó bị mấy widget phía dưới che đi mất
Làm sao giờ anh
[quote=AUTHOR name=fdquote]Cam on anh nhieu
Nhung anh co the chi cach lam sao de thuc hien thu thuat khac cua anh khi ma file js k duoc cung cap nua anh
chi chi tiet luon nha[/quote]
ban oi, neu nhu code HTML cua minh ko co DocType thi no khong co chay. co cach nao khong dung doctype ma van chay khong
Menu rất đẹp, load nhanh. Thủ thuật này rất hữu ích. Mình vừa add vào template của blog mình www.doimoigiaoduc.com
hay thế. đúng là pro
a oi e lam theo cach cua anh nhung no cu bi co menu... chinh hoai ko duoc a giup e moi
http://vnforumgame.blogspot.com/
A nào cho e hỏi , sau nó hg sổ menu xuống được . A nào chỉ dùm e http://zoroblogger.blogspot.com/
E lấy cái menu trang này cũng không sổ xuống được a nào giúp với
http://nguyenhaicntt.blogspot.com/ . E đang làm tiểu luận nên a nào biết chỉ cho e gấp với . thank nhiều
Mình muốn tăng cỡ chữ lên thì làm như thế nào ạ! thnks. http://www.chodoanluanvan.com/
menu này hạn chế người truy cập , ở những tiệm nét bình thường chưa chắc có fire fox hay explor 7. trở lên đâu. google chrome sợ còn không có nữa là.
anh Dũng cho em hỏi có cách nào khi rê chuột vô một menu thì tất cả các menu con cùng xổ xuống luôn không anh giống thế này http://fifaonline.go.vn/default.aspx
Chào Bạn Dũng bạn có thể update lại các link background bi die của data.fan....hay không..? Thanks...!
Admin Fix lại các link ảnh này với nha.
[quote]http://data.fandung.com/blog/demo/Mega-Dropdown-MenuCSS/img/right-li-nobg.png
http://data.fandung.com/blog/demo/Mega-Dropdown-MenuCSS/img/top-li-hv.png
http://data.fandung.com/blog/demo/Mega-Dropdown-MenuCSS/img/home-ico-bg.png [/quote]
hoặc có thể add vào 1 thư mục và cho đường link download duoc không admin ơi !
quá hay, mà hình như bạn mới đổi tên miền nhỉ ?
mình làm thì ok mỗi tội xong thì cái menu lại ở phía sau cái main. không biết làm thế nào để ra trước
» Nội dung phải liên quan tới chủ đề bài viết.
» Có thể sử dụng thẻ trích dẫn [quote], cấu trúc thẻ như bên dưới :
[quote=AUTHOR name=fdquote]NỘI DUNG[/quote]
» Có thể sử dụng các thẻ <b>,<i>,<a>.
BlOg FD chính thức đóng comment của khách ẩn danh.
BlOg FD.