溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

ng-animate和ng-cookies怎么在Angular中使用

發(fā)布時(shí)間:2021-04-01 17:26:09 來源:億速云 閱讀:122 作者:Leah 欄目:web開發(fā)

這篇文章給大家介紹ng-animate和ng-cookies怎么在Angular中使用,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

ng-animate

首先,Angular本生不提供動(dòng)畫機(jī)制,需要在項(xiàng)目中加入Angular插件模塊ngAnimate才能完成Angular的動(dòng)畫機(jī)制,Angular也不提供具體的動(dòng)畫樣式,所以說,它的自由度和可定制性挺大的。

那么,剛開始需要在項(xiàng)目的入口html文件中引入Angular框架(angular.js),然后引入angular.animate.js。

在項(xiàng)目的js入口文件app.js中,新建項(xiàng)目模塊,并且添加所依賴的模塊ng-Animate(有其他需要的模塊的話也可以引入,順序沒關(guān)系)

var demoApp = angular.module('demoApp', ['ngAnimate','ui.router']);

這里中間插入一句,建議Angular中的依賴注入用如下模式,在ads、bds或者其他的前端自動(dòng)化工具打包壓縮后不會(huì)產(chǎn)生問題,因?yàn)閮H僅通過 給function傳參的形式注入依賴,Angular是會(huì)對(duì)注入的變量名有嚴(yán)格的要求(如$scope變量名在控制器中注入時(shí)變量名只能 寫$scope):

//控制器.js、指令.js、過濾器.js的依賴注入建議都用這種方式寫
//這是ui-route的配置,在app.js
demoApp.config(['$stateProvider', '$urlRouterProvider',function($stateProvider, $urlRouterProvider){
 // your code.
}]);

好了,回到正題上。引入了ngAnimate之后,Angular的動(dòng)畫機(jī)制就能生效了。

Angular文檔中寫到如下指令和支持的動(dòng)畫

ng-animate和ng-cookies怎么在Angular中使用

那么,怎么使用呢? 本文拿ng-repeat這個(gè)指令來做個(gè)介紹,其他的一些指令使用方式幾乎相同,可類推。

ng-repeat 主要是對(duì)一個(gè)list的展示,這些元素是是被創(chuàng)建出來加入到DOM結(jié)構(gòu)中去的,那么,它的動(dòng)畫過程為:

創(chuàng)建元素 -> .ng-enter -> .ng-enter-active -> 完成,呈默認(rèn)狀態(tài)

默認(rèn)狀態(tài) -> .ng-leave -> .ng-leave-active -> 銷毀元素

所以可以通過設(shè)置.ng-enter(.ng-leave) 和 .ng-enter-active(.ng-leave-active) 的樣式,加上css3的動(dòng)畫來顯示出動(dòng)畫,如:

<!-- HTML片段 -->
<div ng-init="users = [1,2,3,4,5]"></div>
<input class="filter-btn" type="search" ng-model="u" placeholder="search item" aria-label="search item" />
<ul>
<li class="item" ng-repeat="user in users | filter: u as result">
 {{user}}
</li>
</ul>
/* css片斷 */
/*ng-repeat的元素*/
.item{
 -webkit-transition: all linear 1s;
 -o-transition: all linear 1s;
 transition: all linear 1s;
}
/*動(dòng)畫開始前*/
.item.ng-enter{
 opacity:0;
}
/*動(dòng)畫過程*/
.item-ng-enter-active{
 opacity:1;
}

這樣的效果是對(duì)所有元素同時(shí)應(yīng)用,可能實(shí)際運(yùn)用中需要有一個(gè)先后的漸變出現(xiàn)的效果,這時(shí)候可以設(shè)置ng-enter-stagger來實(shí)現(xiàn).

/*不同時(shí)出現(xiàn)*/

.item.ng-enter-stagger {

 transition-delay:0.5s;

 transition-duration:0s;

}

同樣的,這些angular animate提供的動(dòng)畫的class也可以應(yīng)用到頁面切換中去。自定義動(dòng)畫(基于class)

 在添加移除class時(shí)自定義動(dòng)畫

.class-add     ->   .class-add-active  ->   .class

如果通過寫css的方式還無法滿足需求,當(dāng)然,還可以通過JS的方式來控制動(dòng)畫,下面的代碼你可以理解為是一個(gè)模版

/* CLASS 是需要應(yīng)用的class名,handles是支持的操作,如下圖所示*/
/* 這里如果是應(yīng)用在ui-view 的class上,模版會(huì)疊加(坑)*/
demoApp.animation('.classname',function(){
return {
 'handles':function(element,className,donw){
  //... your code here
  //回調(diào)
  return function(cancelled){
  // alert(1);
  }
 }
 }
})

支持的操作:

ng-animate和ng-cookies怎么在Angular中使用

ng-cookies

$cookies[name] = value;

這個(gè)是angular設(shè)置cookies方法

$cookieStore
提供一個(gè)被session cookies支持的鍵值對(duì)(字符串-對(duì)象)存儲(chǔ)。被存入和取出的對(duì)象將自動(dòng)通過angular的toJson/fromJson進(jìn)行序列化/反序列化。

$cookies
提供瀏覽器cookies的讀/寫訪問操作。

這兩個(gè)都要引入ngCookies模塊才能使用,這個(gè)模塊在1.4版本之后就有了

從源碼中得知$cookieStore返回了三個(gè)方法get put remove 他們分別用toJson/fromJson進(jìn)行序列化/反序列化

簡單的寫了幾個(gè)例子來測試下

<!DOCTYPE html>
<html ng-app="AutumnsWindsApp" ng-controller="aswController">
 <head>
  <meta charset="UTF-8">
  <title></title>
 </head>
 <script src="http://code.angularjs.org/1.2.9/angular.min.js"></script>
 <script src="http://code.angularjs.org/1.2.9/angular-cookies.min.js"></script>
<body>
  {{title}}
 </body>
 <script>
  var AutumnsWindsApp = angular.module('AutumnsWindsApp', ['ngCookies']);
  AutumnsWindsApp.controller('aswController', function($cookies, $cookieStore, $scope) {
   $cookies.name = 'autumnswind';
   $scope.title = "Hello, i'm autumnswind :)";
   $cookieStore.put("skill", "##");
   //刪除cookies
   $cookieStore.remove("name");
   //設(shè)置過期日期
   var time = new Date().getTime() + 5000;
   $cookieStore.put("cookie", "Hello wsscat", {
    expires: new Date(new Date().getTime() + 5000)
   });

   $cookieStore.put("objCookie", {
    value: "wsscat cat cat",
    age: "3",
 }, {
  expires: new Date(new Date().getTime() + 5000)
   });
   console.log($cookies);
   console.log($cookies['objCookie']);
  })
 </script>
</html>

其實(shí)平時(shí)我們這樣就可以把自己需要的cookies設(shè)置進(jìn)去

$cookies.name = 'autumnswind';

但是當(dāng)我們要設(shè)置一個(gè)有效時(shí)間的時(shí)候我們就用這樣的方法把它設(shè)置進(jìn)去

var time = new Date().getTime() + 5000;
   $cookieStore.put("cookie", "Hello wsscat", {
    expires: new Date(new Date().getTime() + 5000)
   });

我們還可以進(jìn)行刪除等操作

$cookieStore.remove("name");

補(bǔ)充:

ng-repeat-track by用法:

<div ng-repeat="links in slides">
 <div ng-repeat="link in links track by $index">{{link.name}}</div>
</div>

Error: [ngRepeat:dupes]這個(gè)出錯(cuò)提示具體到題主的情況,意思是指數(shù)組中有2個(gè)以上的相同數(shù)字。ngRepeat不允許collection中存在兩個(gè)相同Id的對(duì)象

For example: item in items is equivalent to item in items track by $id(item). This implies that the DOM elements will be associated by item identity in the array.
對(duì)于數(shù)字對(duì)象來說,它的id就是它自身的值,因此,數(shù)組中是不允許存在兩個(gè)相同的數(shù)字的。為了規(guī)避這個(gè)錯(cuò)誤,需要定義自己的track by表達(dá)式。例如:

item in items track by item.id或者item in items track by fnCustomId(item)。
嫌麻煩的話,直接拿循環(huán)的索引變量$index來用item in items track by $index

自定義服務(wù)的區(qū)別:

factory()----函數(shù)可以返回簡單類型、函數(shù)乃至對(duì)象等任意類型的數(shù)據(jù) 一般最為常用
service()-----函數(shù)數(shù)組、對(duì)象等數(shù)據(jù)
factory和service不同之處在于,service可以接收一個(gè)構(gòu)造函數(shù),當(dāng)注入該服務(wù)時(shí)通過該函數(shù)并使用new來實(shí)例化服務(wù)對(duì)象

constant()----value()方法和constant()方法之間最主要的區(qū)別是,常量可以注入到配置函數(shù)中,而值不行,value可與你修改,constant不能修改

關(guān)于ng-animate和ng-cookies怎么在Angular中使用就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI