head上的搜索和导航动画。。。

This commit is contained in:
罗宪 2015-05-25 18:26:24 +08:00
parent 4fb6722e3f
commit 7a97c50d03
3 changed files with 99 additions and 9 deletions

View File

@ -15,4 +15,90 @@ $(function() {
function slideToggleCode(item) {
$(item).find('.highlight').slideToggle(150);
}
var navFunc={
navStrArr: [],
init:function (){
var self=this;
self.navBox = $(".nav");
self.navBar = self.navBox.find(".bar");
self.navList = self.navBox.find("ul li");
for(var i=0;i<self.navList.length;i++){
var linkStr=self.navList.eq(i).find("a").attr("href")//.replace(".html","").replace(/.*#/, "/").split("/")[0];
linkStr=linkStr==""?"index":linkStr;
self.navStrArr.push(linkStr)
}
self.search($(".search"));
self.getUrl();
self.navBarAnim();
self.navResize(null);
$(window).bind("resize", self.navResize);
},
navResize: function (e) {
var self = navFunc;
self.navBar.css("left", self.navList.width() * self.navNum)//.addClass("barAnim");
self.navList.eq(self.navNum).find("a").addClass("hover");
},
getUrl: function () {
var self=this;
var url = location.href;
var urlArr=url.split("/");
var links="/";
for(var i=3;i<urlArr.length;i++){
if(i>=urlArr.length-1){
links+=urlArr[i]
}else{
links+=urlArr[i]+"/"
}
}
for (var i = 0; i < self.navStrArr.length; i++) {
if(links=="/"){
self.navNum=0;
break;
}
if ((self.navStrArr[i].indexOf(links)>=0||links.indexOf(self.navStrArr[i])>=0)&&i!==0) {
self.navNum = i;
break;
}
}
},
search: function (c) {
var self = this;
self.searchBox = c;
self.searchInput = self.searchBox.find("input[type='text']");
self.searchBtn = self.searchBox.find("button");
self.searchInput.focus(function (e) {
$(this).addClass("focus");
self.searchBtn.css("left", self.searchBox.width() + 13);
});
self.searchInput.blur(function (e) {
if (!self.searchInput.val()) {
self.searchBtn.attr("style", "");
$(this).removeClass("focus");
}
});
self.searchBtn.click(function (e) {
self.searchBox.find("form").submit();
})
},
navBarAnim: function () {
var self = this,delay;
function startBarAnim(num) {
self.navBar.css("left", self.navList.width() * num);
self.navList.eq(num).find("a").addClass("hover");
}
self.navList.bind("mouseenter", function (e) {
clearTimeout(delay);
var m = e.currentTarget;
self.navList.find("a").removeClass("hover");
self.navBar.addClass("barAnim").css("left", $(m).width() * $(m).index())
});
self.navList.bind("mouseleave", function (e) {
delay = setTimeout(function () {
startBarAnim(self.navNum)
}, 500);
});
}
};
navFunc.init()
});

View File

@ -91,9 +91,9 @@ header {
.search input:-ms-input-placeholder {
color: #CADCE3;
}
.search input:focus {
.search form .focus {
padding: 0 20px 0 0;
width: 150px;
/*width: 150px;*/
}
.search button {
position: absolute;
@ -172,7 +172,10 @@ header {
top: 0;
left: 0;
background: #6EB4E0;
transition: left .3s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.barAnim{
transition: left .3s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.nav-phone-icon {
display: none;

View File

@ -31,23 +31,24 @@
</form>
</div>
<nav class="nav">
<span class="bar"></span>
<ul>
<li class="{%- if post.meta.filepath === 'README.md' %}current{%- endif %}">
<li >
<a href="/">首页</a>
</li>
<li class="{%- if post.filename === 'start' %}current{%- endif %}">
<li >
<a href="/docs/start">上手</a>
</li>
<li class="{%- if post.filename === 'design' %}current{%- endif %}">
<li >
<a href="/docs/design">设计</a>
</li>
<li class="{%- if post.meta.template === 'component' %}current{%- endif %}">
<li >
<a href="/components/button">组件</a>
</li>
<li class="{%- if post.filename === 'modes' %}current{%- endif %}">
<li >
<a href="/docs/modes">模式</a>
</li>
<li class="{%- if post.filename === 'cases' %}current{%- endif %}">
<li >
<a href="/docs/cases">案例</a>
</li>
<li class="{%- if post.filename === 'download' %}current{%- endif %}">