mirror of
https://github.com/ant-design/ant-design.git
synced 2024-11-27 20:49:53 +08:00
head上的搜索和导航动画。。。
This commit is contained in:
parent
4fb6722e3f
commit
7a97c50d03
@ -15,4 +15,90 @@ $(function() {
|
|||||||
function slideToggleCode(item) {
|
function slideToggleCode(item) {
|
||||||
$(item).find('.highlight').slideToggle(150);
|
$(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()
|
||||||
});
|
});
|
||||||
|
@ -91,9 +91,9 @@ header {
|
|||||||
.search input:-ms-input-placeholder {
|
.search input:-ms-input-placeholder {
|
||||||
color: #CADCE3;
|
color: #CADCE3;
|
||||||
}
|
}
|
||||||
.search input:focus {
|
.search form .focus {
|
||||||
padding: 0 20px 0 0;
|
padding: 0 20px 0 0;
|
||||||
width: 150px;
|
/*width: 150px;*/
|
||||||
}
|
}
|
||||||
.search button {
|
.search button {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
@ -172,7 +172,10 @@ header {
|
|||||||
top: 0;
|
top: 0;
|
||||||
left: 0;
|
left: 0;
|
||||||
background: #6EB4E0;
|
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 {
|
.nav-phone-icon {
|
||||||
display: none;
|
display: none;
|
||||||
|
@ -31,23 +31,24 @@
|
|||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
<nav class="nav">
|
<nav class="nav">
|
||||||
|
<span class="bar"></span>
|
||||||
<ul>
|
<ul>
|
||||||
<li class="{%- if post.meta.filepath === 'README.md' %}current{%- endif %}">
|
<li >
|
||||||
<a href="/">首页</a>
|
<a href="/">首页</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="{%- if post.filename === 'start' %}current{%- endif %}">
|
<li >
|
||||||
<a href="/docs/start">上手</a>
|
<a href="/docs/start">上手</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="{%- if post.filename === 'design' %}current{%- endif %}">
|
<li >
|
||||||
<a href="/docs/design">设计</a>
|
<a href="/docs/design">设计</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="{%- if post.meta.template === 'component' %}current{%- endif %}">
|
<li >
|
||||||
<a href="/components/button">组件</a>
|
<a href="/components/button">组件</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="{%- if post.filename === 'modes' %}current{%- endif %}">
|
<li >
|
||||||
<a href="/docs/modes">模式</a>
|
<a href="/docs/modes">模式</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="{%- if post.filename === 'cases' %}current{%- endif %}">
|
<li >
|
||||||
<a href="/docs/cases">案例</a>
|
<a href="/docs/cases">案例</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="{%- if post.filename === 'download' %}current{%- endif %}">
|
<li class="{%- if post.filename === 'download' %}current{%- endif %}">
|
||||||
|
Loading…
Reference in New Issue
Block a user