欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

給angular加上動畫效遇到的問題總結(jié)

 更新時間:2016年02月17日 11:59:33   投稿:hebedich  
本文給大家總結(jié)了一下在angular中給ng-repeat列表加上動畫效果時所遇到的問題及解決方法,推薦給大家,希望大家能夠喜歡。

加入“動效”是讓用戶對應(yīng)用的行為進行感知的一種有效手段。“列表”是應(yīng)用中最常使用的一種界面形式,經(jīng)常會有添加行,刪除行,移動行這些操作。設(shè)想添加的操作很簡單,刪除時從大到小,然后消失;添加時從小到大;移動就是先刪除再添加。感覺上并不復雜,應(yīng)該利用CSS的transition就能搞定,可是實際做起來發(fā)現(xiàn)有不少問題要處理,下面一一道來。

來些簡單的測試

1、最初的版本

<div class='list'>
  <div class='row-1'>row-1</div>
  <div class='row-2'>row-2</div>
</div>
.list{margin:20px;background:#eee;font-size:18px;color:white;}
.row-1{background:green;overflow:hidden;padding:15px;}
.row-2{background:blue;padding:15px;}
/*demo1*/
.demo-1 .remove{-webkit-transition: height 3s linear;}
.demo-1 .remove.active{height:0;}
var ele = document.querySelector('.demo-1 .row-1');
ele.classList.add('remove');
ele.classList.add('active');

想法很簡單,通過添加“remove”類,設(shè)置動畫的效果,添加“active”修改css屬性,激活動畫。

結(jié)果和想的不一樣,兩個問題:1、動畫并沒有運行;2、row-1并沒有消失。為什么?首先,CSS的transition不能作用于auto的屬性,因為row-1本來并沒有設(shè)置height,所以不會產(chǎn)生從現(xiàn)有的高度變到0的動畫。第二,height=0只是設(shè)置了content區(qū)域為0,padding并沒有改變,所以還是row-1還是占據(jù)了30px的空間。

2、指定固定的height并且padding也加上動畫

調(diào)整CSS

/*demo2*/
.demo-2 .row-1{height:48px;}
.demo-2 .remove{-webkit-transition: height 3s linear, padding-top 3s linear;}
.demo-2 .row-1.remove.active{height:0;padding-top:0;padding-bottom:0;}

這次的效果是對的,row-1從48px邊到0,同時padding也跟著變。

3、還有沒有別的辦法呢?一定要指定height嗎?transform行不行

修改CSS

/*demo3*/
.demo-3 .remove{-webkit-transition: -webkit-transform 3s linear,padding 0s linear 3s;}
.demo-3 .row-1.remove.active{-webkit-transform-origin:0 0;-webkit-transform:scaleY(0);}


即使沒有設(shè)置height,通過transform執(zhí)行動畫也是沒有問題的。問題是,row-1還在原來的地方,還占著空間,row-2并沒有向上挪。由此帶來個問題,動畫執(zhí)行完了(包括第2個設(shè)置height的例子),row-1并沒有刪除掉,只是看不見了。

4、解決動畫執(zhí)行完清除元素的問題

修改CSS

復制代碼 代碼如下:

.demo-4 .remove{-webkit-transition: height 3s linear, padding 3s linear, opacity 3s linear,color .5s linear;}
.demo-4 .row-1.remove.active{padding-top:0;padding-bottom:0;color:rgba(0,0,0,0);opacity:0;}

修改JS

var ele, l;
ele = document.querySelector('.demo-4 .row-1');
l = ele.addEventListener('webkitTransitionEnd', function(evt){
  if (evt.propertyName === 'height') {
    ele.style.display = 'none';   
    ele.style.height = '';
    ele.removeEventListener('webkitTransitionEnd', l, false);
  }
}, false);
ele.style.height = ele.offsetHeight + 'px';
ele.classList.add('remove');
$timeout(function(){
  ele.classList.add('active');
  ele.style.height = '0px';
});

這次的效果不錯。有幾個注意的地方:1、通過注冊transitionEnd事件可以捕獲到動結(jié)束;2、可以同時執(zhí)行多個動效,每個東西結(jié)束都會產(chǎn)生transitionEnd事件,通過事件的“propertyName”可以知道是哪個屬性的動效結(jié)束了。

5、用velocity.js也試了一下

CSS不用設(shè)置
JS代碼

var ele = document.querySelector('.demo-5 .row-1');
Velocity(ele, 'slideUp', { duration: 1000 });

看了看執(zhí)行的過程,也是修改height和padding。但是,velocity用的是requestAnimationFrame函數(shù)。我認為如果動效比較簡單,就不用引入其他的庫了,直接寫出來的運行效果差不多。

6、高度搞明白了,變寬度呢?

調(diào)整CSS

.demo-6 .row-1{width:100%;}
.demo-6 .remove{-webkit-transition: width 3s linear;}
.demo-6 .row-1.remove.active{width:0%;}

雖然寬本身可以通過百分比進行設(shè)置,但是height不固定的問題還是存在。

7、用上JS解決變width的問題

設(shè)置CSS

.demo-7 .row-1{width:100%;height:48px;}
.demo-7 .remove{-webkit-transition: width 3s linear, opacity 3s ease;}
.demo-7 .row-1.remove.active{width:0%;opacity:0;}

固定了height已有動效正常了。其他的改進可參照前面的例子了。

二、一個完整的例子

完整的例子實在angular中實現(xiàn)的。angular實現(xiàn)首先一個問題就是在什么時機設(shè)置動效?因為,angular是雙向綁定的,如果在controller中刪除了一個對象,渲染界面的時候這個對象就沒了,所以必須介入到數(shù)據(jù)綁定的過程中。angular提供ngAnimatie這個動畫模塊,試了一下它也確實可以完成ngRepeat列表數(shù)據(jù)更新的動效。但是要額外引入angular-animation.js,雖然不大,還是覺得不是很有必要。另外,我是在一個已經(jīng)寫好的框架頁面上加動畫,如果需要引入新的module,需要改框架文件,我覺得不好。試了試動態(tài)加載animation模塊也沒成功,所以就研究了一下自己怎么控制動效。

angular即使不加載animation模塊,也有一個$animate,它為動效控制留出了接口。
看JS

var fnEnter = $animate.enter,
  fnLeave = $animate.leave;
$animate.enter = function() {
  var defer = $q.defer(),
    e = arguments[0],
    p = arguments[1],
    a = arguments[2],
    options = {
      addClass: 'ng-enter'
    };
  fnEnter.call($animate, e, p, a, options).then(function() {
    $animate.addClass(e, 'ng-enter-active').then(function(){
      var l = e[0].addEventListener('webkitTransitionEnd', function(){
        e[0].classList.remove('ng-enter-active');
        e[0].classList.remove('ng-enter');
        e[0].removeEventListener('webkitTransitionEnd', l, false);
        defer.resolve();
      }, false); 
    });
  });
  return defer.promise;
};
$animate.leave = function() {
  var defer = $q.defer(),
    e = arguments[0];
  $animate.addClass(e, 'ng-leave').then(function(){
    $animate.addClass(e, 'ng-leave-active').then(function(){
      var l = e[0].addEventListener('webkitTransitionEnd', function(){
        fnLeave.call($animate, e).then(function(){
          defer.resolve();
        });
      }, false);
    });
  });
  return defer.promise;
};

ng-repeat進行數(shù)據(jù)更新是會調(diào)用$animate服務(wù)的enters,leave和move方法,所以,要自己控制動效就要重寫對應(yīng)的方法。重寫的時候要用$animate添加,直接在dom上設(shè)置有問題。(這一段的angular的邏輯比較底層,沒有太看明白,還需要深入研究。)

另外,在移動行的位置時,要通過$timeout將刪除和插入放到兩個digest循環(huán)中處理,否則看不出效果。

var index = records.indexOf($scope.selected),
  r = records.splice(index, 1);
$timeout(function(){
  records.splice(index + 1, 0, r[0]);
},500);

angular的動畫和digest循環(huán)關(guān)系密切,看了angular-animation.js的代碼沒看明白,還需要深入研究才行。

相關(guān)文章

  • 由淺入深剖析Angular表單驗證

    由淺入深剖析Angular表單驗證

    這篇文章主要介紹了由淺入深剖析Angular表單驗證 的相關(guān)資料,需要的朋友可以參考下
    2016-07-07
  • AngularJS基礎(chǔ) ng-non-bindable 指令詳細介紹

    AngularJS基礎(chǔ) ng-non-bindable 指令詳細介紹

    本文主要講解AngularJS ng-non-bindable 指令,這里幫大家整理了ng-non-bindable指令的基本知識資料,有需要的小伙伴可以參考下
    2016-08-08
  • Angular 5.x 學習筆記之Router(路由)應(yīng)用

    Angular 5.x 學習筆記之Router(路由)應(yīng)用

    本篇文章主要介紹了Angular 5.x 學習筆記之Router(路由)應(yīng)用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • Angular.js自動化測試之protractor詳解

    Angular.js自動化測試之protractor詳解

    Protractor是一個建立在WebDriverJS基礎(chǔ)上的端到端(E2E)的AngularJS JavaScript Web應(yīng)用程序測試框架,下面這篇文章主要給大家介紹了angular.js自動化測試之protractor的相關(guān)資料,需要的朋友可以參考下。
    2017-07-07
  • AngularJs表單校驗功能實例代碼

    AngularJs表單校驗功能實例代碼

    這篇文章主要介紹了AngularJs表單校驗功能實例代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-02-02
  • AngularJS入門教程之ng-checked 指令詳解

    AngularJS入門教程之ng-checked 指令詳解

    本文主要講解AngularJS ng-checked 指令,在這整理ng-checked 指令的基礎(chǔ)知識,并附代碼實例,有需要的小伙伴可以參考下
    2016-08-08
  • AngularJS使用ng-app自動加載bootstrap框架問題分析

    AngularJS使用ng-app自動加載bootstrap框架問題分析

    這篇文章主要介紹了AngularJS使用ng-app自動加載bootstrap框架問題,分析了前面文章中所述的ng-app自動加載bootstrap出現(xiàn)的錯誤原因與相應(yīng)的解決方法,需要的朋友可以參考下
    2017-01-01
  • Angular的MVC和作用域

    Angular的MVC和作用域

    本文主要Angular的MVC和作用域進行詳細分析介紹,具有一定的參考價值,下面跟著小編一起來看下吧
    2016-12-12
  • 淺析AngularJs HTTP響應(yīng)攔截器

    淺析AngularJs HTTP響應(yīng)攔截器

    這篇文章主要介紹了淺析AngularJs HTTP響應(yīng)攔截器的相關(guān)資料,需要的朋友可以參考下
    2015-12-12
  • AngularJS中實現(xiàn)顯示或隱藏動畫效果的方式總結(jié)

    AngularJS中實現(xiàn)顯示或隱藏動畫效果的方式總結(jié)

    AngularJS 是一組用于創(chuàng)建單頁Web應(yīng)用的豐富框架,給構(gòu)建豐富交互地應(yīng)用帶來了所有功能,其中一項主要的特性是Angular對動畫的支持。下面通過本文給大家介紹AngularJS中實現(xiàn)顯示或隱藏動畫效果的方式總結(jié),對angularjs動畫效果相關(guān)知識感興趣的朋友一起學習
    2015-12-12

最新評論