基于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 相关文章推荐
js如何判断不同系统的浏览器类型
Oct 28 Javascript
jquery垂直公告滚动实现代码
Dec 08 Javascript
jquery滚动特效集锦
Jun 03 Javascript
jQuery实现Meizu魅族官方网站的导航菜单效果
Sep 14 Javascript
使用微信内置浏览器点击下拉框出现页面乱跳转现象(iphone),该怎么办
Jan 04 Javascript
深入理解jQuery事件绑定
Jun 02 Javascript
Javascript 基础---Ajax入门必看
Jul 06 Javascript
Bootstrap table简单使用总结
Feb 15 Javascript
微信小程序使用audio组件播放音乐功能示例【附源码下载】
Dec 08 Javascript
Vue 表情包输入组件的实现代码
Jan 21 Javascript
微信端调取相册和摄像头功能,实现图片上传,并上传到服务器
May 16 Javascript
小程序实现投票进度条
Nov 20 Javascript
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内核解析:PHP中的哈希表
2014/01/30 PHP
WordPress中重置文章循环的rewind_posts()函数讲解
2016/01/11 PHP
Zend Framework教程之响应对象的封装Zend_Controller_Response实例详解
2016/03/07 PHP
关于PHP内置的字符串处理函数详解
2017/02/04 PHP
PHP面向对象程序设计内置标准类,普通数据类型转为对象类型示例
2019/06/12 PHP
js继承 Base类的源码解析
2008/12/30 Javascript
IE6下出现JavaScript未结束的字符串常量错误的解决方法
2010/11/21 Javascript
javascript中获取下个月一号,是星期几
2012/06/01 Javascript
JS继承--原型链继承和类式继承
2013/04/08 Javascript
js 判断上传文件大小及格式代码
2013/11/13 Javascript
javascript实例分享---具有立体效果的图片特效
2014/06/08 Javascript
jQuery中height()方法用法实例
2014/12/24 Javascript
js获取新浪天气接口的实现代码
2016/06/06 Javascript
总结Node.js中的一些错误类型
2016/08/15 Javascript
AngularJS之页面跳转Route实例代码
2017/03/10 Javascript
使用JS在浏览器中判断当前网络连接状态的几种方法
2017/05/05 Javascript
原生javascript实现的全屏滚动功能示例
2017/09/19 Javascript
vue的一个分页组件的示例代码
2017/12/25 Javascript
ES6之模版字符串的具体使用
2018/05/17 Javascript
JS实现点击按钮可实现编辑功能
2018/07/03 Javascript
详解vue axios用post提交的数据格式
2018/08/07 Javascript
详解vue-cli 2.0配置文件(小结)
2019/01/14 Javascript
js计时事件实现圆形时钟
2020/03/25 Javascript
JavaScript异步操作的几种常见处理方法实例总结
2020/05/11 Javascript
JS实现悬浮球只在一侧滑动并且是横屏状态下
2020/08/19 Javascript
JavaScript中的执行环境和作用域链
2020/09/04 Javascript
python实现颜色rgb和hex相互转换的函数
2015/03/19 Python
Python读取文件内容的三种常用方式及效率比较
2017/10/07 Python
python将四元数变换为旋转矩阵的实例
2019/12/04 Python
行政主管岗位职责
2013/11/18 职场文书
洗煤厂厂长岗位职责
2014/01/03 职场文书
大学毕业生自荐书怎么写?
2014/01/06 职场文书
公证书标准格式
2014/04/10 职场文书
幼儿园迎国庆65周年活动策划方案
2014/09/16 职场文书
Python中Permission denied的解决方案
2021/04/02 Python
MySQL索引失效十种场景与优化方案
2023/05/08 MySQL