如何让javascript动画在href运行之前完成
How do I let javascript animation finish before href is running
当我在项目中将href设置为网站时,javascript动画在进入网站之前不会完成。但如果我设置href="#0",它会起作用。
有人说X.preventDefault会起作用,但事实并非如此。
感谢我能得到的任何帮助:)。
Javascript:
jQuery(document).ready(function($){
//toggle 3d navigation
$('.cd-3d-nav-trigger').on('click', function(){
toggle3dBlock(!$('.cd-header').hasClass('nav-is-visible'));
});
//select a new item from the 3d navigation
$('.cd-3d-nav a').on('click', function(){
var selected = $(this);
selected.parent('li').addClass('cd-selected').siblings('li').removeClass('cd-selected');
updateSelectedNav('close');
});
$(window).on('resize', function(){
window.requestAnimationFrame(updateSelectedNav);
});
function toggle3dBlock(addOrRemove) {
if(typeof(addOrRemove)==='undefined') addOrRemove = true;
$('.cd-header').toggleClass('nav-is-visible', addOrRemove);
$('main').toggleClass('nav-is-visible', addOrRemove);
$('.cd-3d-nav-container').toggleClass('nav-is-visible', addOrRemove);
}
//this function update the .cd-marker position
function updateSelectedNav(type) {
var selectedItem = $('.cd-selected').preventDefault(),
selectedItemPosition = selectedItem.index() + 1,
leftPosition = selectedItem.offset().left,
backgroundColor = selectedItem.data('color');
$('.cd-marker').removeClassPrefix('color').addClass('color-'+ selectedItemPosition).css({
'left': leftPosition,
});
if( type == 'close') {
$('.cd-marker').one('webkitTransitionEnd otransitionend oTransitionEnd msTransitionEnd transitionend', function(){
toggle3dBlock(false);
});
}
}
$.fn.removeClassPrefix = function(prefix) {
this.each(function(i, el) {
var classes = el.className.split(" ").filter(function(c) {
return c.lastIndexOf(prefix, 0) !== 0;
});
el.className = $.trim(classes.join(" "));
});
return this;
};
});
HTML:
<header class="cd-header">
<a href="#0" class="cd-logo"><img src="img/cd-logo.svg" alt="Logo"></a>
<a href="#0" class="cd-3d-nav-trigger">
Menu
<span></span>
</a>
</header> <!-- .cd-header -->
<nav class="cd-3d-nav-container">
<ul class="cd-3d-nav">
<li class="cd-selected">
<a href="Default.aspx">Home</a>
</li>
<li>
<a href="aboutme.aspx>About me</a>
</li>
<li>
<a href="Portfolio.aspx" onclick="">Portfolio</a>
</li>
<li>
<a href="Vouge approved.aspx">Vouge approved</a>
</li>
<li>
<a href="Contact information.aspx">Contact information</a>
</li>
</ul> <!-- .cd-3d-nav -->
<span class="cd-marker color-1"></span>
</nav> <!-- .cd-3d-nav-container -->
使用preventDefault
可以停止导航,但动画完成后必须使用代码进行导航。
向updateSelectedNav
添加一个回调,以便在动画完成时使用它来执行某些操作:
function updateSelectedNav(type, callback) {
在转换结束的事件中调用它:
if( type == 'close') {
$('.cd-marker').one('webkitTransitionEnd otransitionend oTransitionEnd msTransitionEnd transitionend', function(){
toggle3dBlock(false);
if (typeof callback == 'function') callback();
});
}
现在,您可以使用preventDefault
停止导航,并在动画完成时执行此操作:
$('.cd-3d-nav a').on('click', function(e){
e.preventDefault();
var selected = $(this);
selected.parent('li').addClass('cd-selected').siblings('li').removeClass('cd-selected');
updateSelectedNav('close', function(){
window.location.href = selected.attr('href');
});
});
相关文章:
- 如何使用phaser使html5游戏在移动设备浏览器上运行
- 使用压缩的JavaScript文件(不是运行时压缩)
- Javascript运行php文件,然后下载文件
- chrome扩展:尽管运行了at:documentidle,js脚本还是过早启动
- 我已经创建了一个jquery转盘,并使用if条件来运行和停止转盘
- 在单击href链接的同时下载文件
- Angularjs代码未在匿名函数中运行
- jquery设置为使用参数运行
- 如何根据时间运行不同的脚本
- 使用 Javascript 在运行时禁用<一个 href>
- jquery在李内部的href上运行函数
- 如何让javascript动画在href运行之前完成
- javaScript 如果 window.location.href 包含 url1 则不运行,否则运行它
- 正文加载上的 HTML 运行 href 链接
- 如何在Anchor标记(<a>)中运行onClick和href
- 正在尝试使用href运行javascript进行验证
- JavaScript运行完整的A href命令
- 在运行时用你自己的url更改href标签
- 确保jQuery on click在href触发之前运行
- 如何通过javascript在运行时设置href值