基于javascript实现漂亮的页面过渡动画效果附源码下载


Posted in Javascript onOctober 26, 2015

用户通过点击页面左侧的菜单,对应的页面加载时伴随着滑动过滤动画,并带有进度条效果。当然页面的加载是Ajax驱动的,整个加载过渡过程非常流畅,非常好的用户体验。

HTML

HTML结构中,.cd-main包含页面主体内容,.cd-side-navigation包含着侧边导航条,#cd-loading-bar则是用来做进度条动画用的。

<nav class="cd-side-navigation"> 
  <ul> 
    <li> 
      <a href="index.html" class="selected" data-menu="index"> 
        <svg><!-- svg content here --></svg> 
        Intro 
      </a> 
    </li> 
    <li> 
      <!-- ... --> 
    </li> 
    <!-- other list items here --> 
  </ul> 
</nav> <!-- .cd-dashboard --> 
<main class="cd-main"> 
  <section class="cd-section index visible"> 
    <header> 
      <div class="cd-title"> 
        <h2>Animated Page Transition #2</h2> 
        <span>Some text here</span> 
      </div> 
      <a href="#index-content" class="cd-scroll">Scroll Down</a> 
    </header> 
    <div class="cd-content" id="index-content"> 
      <!-- content here --> 
    </div> <!-- .cd-content --> 
  </section> <!-- .cd-section --> 
</main> <!-- .cd-main --> 
<div id="cd-loading-bar" data-scale="1" class="index"></div> <!-- lateral loading bar -->

CSS

我们将.cd-side-navigation固定在页面左侧,并且设置它的高度为100%,这样左侧导航菜单就始终占据左侧边栏,右侧主体内容滚动时,左侧导航菜单不动。

.cd-side-navigation { 
 position: fixed; 
 z-index: 3; 
 top: 0; 
 left: 0; 
 height: 100vh; 
 width: 94px; 
 overflow: hidden; 
} 
.cd-side-navigation ul { 
 height: 100%; 
 overflow-y: auto; 
} 
.cd-side-navigation::before { 
 /* background color of the side navigation */ 
 content: ''; 
 position: absolute; 
 top: 0; 
 left: 0; 
 height: 100%; 
 width: calc(100% - 4px); 
 background-color: #131519; 
} 
.cd-side-navigation li { 
 width: calc(100% - 4px); 
} 
.cd-side-navigation a { 
 display: block; 
 position: relative; 
} 
.cd-side-navigation a::after { 
 /* 4px line to the right of the item - visible on hover */ 
 content: ''; 
 position: absolute; 
 top: 0; 
 right: -4px; 
 height: 100%; 
 width: 4px; 
 background-color: #83b0b9; 
 opacity: 0; 
} 
.no-touch .cd-side-navigation a:hover::after { 
 opacity: 1; 
}

JavaScript

当我们点击左侧菜单时,调用triggerAnimation()函数,这个函数会触发加载进度条动画函数loadingBarAnimation(),接着加载页面内容函数:loadNewContent()。

function loadingBarAnimation() { 
  var scaleMax = loadingBar.data('scale'); 
  if( scaleY + 1 < scaleMax) { 
    newScaleValue = scaleY + 1; 
  } 
  // ... 
   
  loadingBar.velocity({ 
    scaleY: newScaleValue 
  }, 100, loadingBarAnimation); 
}

当新页面被选中时,一个新的元素.cd-section将会被创建并且插入到DOM中,然后load()新的url内容。

function loadNewContent(newSection) { 
  var section = $('<section class="cd-section overflow-hidden '+newSection+'"></section>').appendTo(mainContent); 
   
  //load the new content from the proper html file 
  section.load(newSection+'.html .cd-section > *', function(event){ 
     
    loadingBar.velocity({ 
      scaleY: scaleMax //this is the scaleY value to cover the entire window height (100% loaded) 
    }, 400, function(){ 
       
      section.addClass('visible'); 
 
      var url = newSection+'.html'; 
 
      if(url!=window.location){ 
        //add the new page to the window.history 
        window.history.pushState({path: url},'',url); 
      } 
 
      // ... 
    }); 
  }); 
}

通过异步加载的页面要返回上一页历史浏览记录的话,可以点击浏览器上的返回即可。返回上一页同样有过渡动画效果。

Javascript 相关文章推荐
JQuery 1.3.2以上版本中出现pareseerror错误的解决方法
Jan 11 Javascript
jquery select多选框的左右移动 具体实现代码
Jul 03 Javascript
jquery中 $.expr使用实例介绍
Jun 09 Javascript
JavaScript实现Iterator模式实例分析
Jun 09 Javascript
JavaScript中反正弦函数Math.asin()的使用简介
Jun 14 Javascript
深入解析jQuery中Deferred的deferred.promise()方法
May 03 Javascript
jQuery实现根据滚动条位置加载相应内容功能
Jul 18 Javascript
一个简单的JavaScript Map实例(分享)
Aug 03 Javascript
jquery仿京东侧边栏导航效果
Mar 02 Javascript
在 Node.js 中使用 async 函数的方法
Nov 17 Javascript
解决新建一个vue项目过程中遇到的问题
Oct 22 Javascript
详解vue3中组件的非兼容变更
Mar 03 Vue.js
JS实现的页面自定义滚动条效果
Oct 26 #Javascript
JS实现的鼠标跟随代码(卡通手型点击效果)
Oct 26 #Javascript
JS响应鼠标点击实现两个滑块区间拖动效果
Oct 26 #Javascript
javaScript实现可缩放的显示区效果代码
Oct 26 #Javascript
JS基于VML技术实现的五角星礼花效果代码
Oct 26 #Javascript
jquery获取url参数及url加参数的方法
Oct 26 #Javascript
JavaScritp添加url参数并将参数加入到url中及更改url参数的方法
Oct 26 #Javascript
You might like
又一个PHP实现的冒泡排序算法分享
2014/08/21 PHP
PHP的Socket网络编程入门指引
2015/08/11 PHP
php求今天、昨天、明天时间戳的简单实现方法
2016/07/28 PHP
PHP运用foreach神奇的转换数组(实例讲解)
2018/02/01 PHP
PHP编程实现的TCP服务端和客户端功能示例
2018/04/13 PHP
PHP实现从PostgreSQL数据库检索数据分页显示及根据条件查找数据示例
2018/06/09 PHP
Prototype使用指南之base.js
2007/01/10 Javascript
利用jQuery接受和处理xml数据的代码(.net)
2011/03/28 Javascript
JS将光标聚焦在文本最后的实现代码
2014/03/28 Javascript
js简单工厂模式用法实例
2015/06/30 Javascript
jQuery实现折叠、展开的菜单组效果代码
2015/09/16 Javascript
javascript省市级联功能实现方法实例详解
2015/10/20 Javascript
Angular学习笔记之angular的$filter服务浅析
2016/11/12 Javascript
JS实现的自动打字效果示例
2017/03/10 Javascript
w3c编程挑战_初级脚本算法实战篇
2017/06/23 Javascript
JS中把函数作为另一函数的参数传递方法(总结)
2017/06/28 Javascript
vue自定v-model实现表单数据双向绑定问题
2018/09/03 Javascript
javascript中数组的常用算法深入分析
2019/03/12 Javascript
Python实现将n个点均匀地分布在球面上的方法
2015/03/12 Python
Python实现的简单文件传输服务器和客户端
2015/04/08 Python
python+opencv+caffe+摄像头做目标检测的实例代码
2018/08/03 Python
python 定义n个变量方法 (变量声明自动化)
2018/11/10 Python
Python3.5内置模块之os模块、sys模块、shutil模块用法实例分析
2019/04/27 Python
Python中的字符串切片(截取字符串)的详解
2019/05/15 Python
Python创建或生成列表的操作方法
2019/06/19 Python
Python数据可视化实现正态分布(高斯分布)
2019/08/21 Python
Python爬虫防封ip的一些技巧
2020/08/06 Python
美国最大的高尔夫发球时间预订网站:TeeOff.com
2018/03/28 全球购物
GANT葡萄牙官方商店:拥有美国运动服传统的生活方式品牌
2018/10/18 全球购物
会计实习生工作总结的自我评价
2013/10/07 职场文书
酒店执行总经理岗位职责
2013/12/15 职场文书
小学师德师风演讲稿
2014/09/02 职场文书
2015年大学生工作总结
2015/04/21 职场文书
义诊活动通知
2015/04/24 职场文书
法律讲堂观后感
2015/06/11 职场文书
C站最全Python标准库总结,你想要的都在这里
2021/07/03 Python