AngularJs应用页面切换优化方案

AngularJs应用页面切换优化方案,第1张

概述本站提供多种CSS样式代码,css入门学习,html静态网站的制作,html编辑器的选择。程序员人生,我编程,我快乐,我富裕 ??

葡萄城的1款尚在研发中的产品,对外名称暂定为X项目。其中使用了已上市的wijmo中SpreadJs产品,另外,在研发进程中整理了1些研发总结分享给大家。如本篇的在页面切换的进程中优化方案,欢迎大家跟帖交换。

前言

AngularJs被用来开发单页面利用程序(SPA),利用AJAX调用配合页面的局部刷新,可以减少页面跳转,从而取得更好的用户体验。Angular的ngVIEw及其对应的强大路由机制,是实现SPA利用的核心模块。本文所说的页面切换指的就是这个路由机制,即根据不同的url展现不同的视图。

有1种非常常见的场景:在切换至新页面后,需要通过AJAX调用从服务器要求1些数据,然后根据这些数据来展现页面。如果未做任何处理,那末页面会先加载新页面的HTML模版,但此时模板中的数据model还并没有被要求,因此会有1段时间显示空数据,非常影响用户体验。

场景

让我们以Angular官方给出的 PhoneCat Tutorial App来讲明这个问题。

在PhoneCat项目的github主页上有这么1段话:“There is no dynamic backend (no application server) for this application. Instead we fake the application server by fetching static Json files.”也就是说,这个示例项目中只是摹拟了1个server,所以当页面要求phones.Json和每一个手机的详细数据时,这些要求会在非常短的时间内就完成了,我们并感觉不到展现页面存在甚么问题。

而在真实的网络环境中,要求这些Json文件可能会消耗相对较长的时间。让我们来摹拟1下网络要求响应时间较长的情况。在这里我用了express来代替原来的http-server,并在客户端要求数据时延迟5秒再做出响应:

运行起来后可以看到,页面立即会显示出来,但是本来应当显示手机列表的区域是1片空白,直到5秒以后才将列表数据显示出来。点击1个手机名称进入详细信息页面,一样是1开始只显示了HTML模板的内容,然后才将参数数据填充到页面上。进程中页面会出现抖动,非常影响用户体验。

使用resolve来提早要求数据

在遇到这个问题时,我最早想到的就是添加1个loading提示:在网络要求前显示loading遮罩图片,网络要求结束后再将其隐藏。因而点击进入手机的detail页面后页面会显现1个loading图片,像下图这样:

可以看到,页面应当显示手机详细数据的区域显示空白,造成非常不好的用户体验。这是由于PhoneDetailCtrl的代码是在页面跳转产生后才履行的,而此时手机信息数据还没有从服务器获得到,也就是说$scope.phone这个model还未被赋值。有无1种办法让这些数据在切换到这个页面之前就先准备好呢?

答案固然是有,也就是这篇文章要介绍的主角――resolve。我们知道ng-vIEw是通过$routeProvIDer来订制页面路由规则,这个路由规则在phonecat项目源码中是这样定义的:

为了让页面跳转之前履行1些事情,我们可以在路由规则中配置resolve参数。

Resolve参数可以注入1组service到路由绑定的controller当中。如果其中的1个或多个service是异步对象($q.defer)时,那末只有当这些异步 *** 作都完成后,页面才会跳转。利用这1点,我们就能够在页面跳转前先将手机详细信息数据要求到本地。跳转后,目标页面就会立即正常显示数据。

我将手机详细信息页面的路由配置代码修改以下:

在上面的代码中,我只能使用$route.current.params来获得phoneID参数,由于此时页面还未跳转,$routeParams是获得不到任何值的。经过这样配置resolve参数后,我就能够在PhoneDetailCtrl中注入1个名为phoneDetailsService的对象。PhoneDetailCtrl的代码以下:

这样,就能够在页面跳转之前获得到要求的数据了。

为页面加入切换动画

为了让页面间的切换更平滑,可以在页面切换加入过渡动画。AngularJs对1些经常使用的指令比如ngRepeat、ngSwitch和ngVIEw都有动画的支持。

AngularJs通过CSS来定义动画,要实现DOM元素的动画效果非常简单。当DOM元素变化的时候,AngularJs会在元素上添加特定的class:

・ ng-enter,当元素被添加时会被利用;

・ ng-move,当元素被移动时会被利用;

・ ng-leave,当元素被删除时会被利用。

我们可以对ng-vIEw利用AngularJs动画,在phone-cat项目中,animation.CSS中的以下代码实现了切换页面的淡入淡出动画:

.vIEw-frame.ng-enter,.vIEw-frame.ng-leave {  background: white;  position: absolute;  top: 0;  left: 0;  right: 0;}.vIEw-frame.ng-enter {  -webkit-animation: 0.5s fade-in;  -moz-animation: 0.5s fade-;  -o-animation: 0.5s fade-;  animation: 0.5s fade-;  z-index: 100leave {  -webkit-animation: 0.5s fade-out;  -moz-animation: 0.5s fade-out;  -o-animation: 0.5s fade-out;  animation: 0.5s fade-out;  z-index: 99;}
总结

在Web利用中,为了取得良好的用户体验,就要在界面上使用1些技能让用户不会感觉到突兀。本文提出了两点技能让AngularJs利用在页面切换时更加自然平滑。

 

完全demo下载地址:AngularJs利用页面切换优化方案

总结

以上是内存溢出为你收集整理的AngularJs应用页面切换优化方案全部内容,希望文章能够帮你解决AngularJs应用页面切换优化方案所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1018494.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-23
下一篇 2022-05-23

发表评论

登录后才能评论

评论列表(0条)

保存