Ionic 的 ng-class 在聊天功能上面的巧妙運用

不少人在問我是 ionic好呢?仍是react好呢? 其實我只想告訴你去看文檔啊,不用用怎麼知道哪一個合適呢? 嘿嘿可是真的這麼問的時候我也不會這麼回答的,那豈不是太張狂了哈哈哈javascript

react我確實沒有用過,因此今天很少作什麼評價。可是ionic我在項目中一直用着,想說的是確實很好用。css

上一篇文章咱們介紹了css3實現聊天界面的佈局。那麼今天咱們就來學習一下,如何在頁面進行數據交互。html

小月博客仿微信聊天界面

文章重點:java

  1. 如何在頁面巧妙的運用ng-class的功能
  2. ng-class有哪些使用方法

接下來咱們就圍繞以上的重點來說述:react

1、如何在頁面巧妙的運用ng-class的功能

上一節咱們已經把頁面的靜態佈局給你們一一講解了,那麼咱們今天來分享一下怎麼動態展現數據,老習慣咱們先看代碼(PS : CSS部分請查看 CSS3 仿微信聊天小氣泡css3

HTMLangularjs

<!-- 聊天界面 -->
 <div ng-class="{true: 'leftd', false: 'rightd'}[isUser(c.sender)]" ng-repeat="c in chatAll">
     <span ng-class="{true: 'leftd_h', false: 'rightd_h'}[isUser(c.sender)]">
         <img ng-src="{{pic(c.sender)}}" />
     </span>
     <div ng-class="{true: 'speech left', false: 'speech right'}[isUser(c.sender)]"> 
         {{c.data}}
     </div>
 </div>

  

Controller.js數組

//返回給個人信息是帶有發送者或者接受者的ID的
 $scope.isUser = function(chatId) {
     if(chatId == cid){
         return true;
     }else{
         return false;
     }
 }; 

注: 在項目中咱們是根據發送者的ID去作判斷的 isUser(c.sender)微信

這裏的判斷就是根據true/false去判斷所要使用的class框架

第2、ng-class有哪些使用方法

在angular中爲咱們提供了3種方案處理class:

  1. :scope變量綁定,如上例。(不推薦使用)
  2. :字符串數組形式。
  3. :對象key/value處理。

在前面Angularjs開發一些經驗總結中咱們說到在angular開發中angular controller never 包含DOM元素(html/css),在controller須要一個簡單的POJO(plain object javascript object),與view徹底的隔離(交互angularjs框架的職責。但在某些項目中看見controller涉及DOM的元素最多的是在controller scope上定義某變量,其值爲class name,形如:

function ctr($scope){
   $scope.test =「classname」;
}

<div class=」{{test}}」></div>

這種方式徹底沒錯,是angular提供的一種改變class的方式,可是在controller涉及了classname在我看來是乎老是那麼詭異,我但願的是controller是一個乾淨的純javascript意義的object。

咱們繼續其餘兩種解決方案:
1字符串數組形式是針對class簡單變化,具備排斥性的變化,true是什麼class,false是什麼class,其形如;

function Ctr($scope) { 
    $scope.isActive = true;
}

<div ng-class="{true: 'active', false: 'inactive'}[isActive]">
</div>

其結果是2中組合,isActive表達式爲true,則 active,負責inactive。

2對象key/value處理主要針對複雜的class混合,其形如:

當 isSelected = true 則增長selected class,
當isCar=true,則增長car class,
因此你結果多是4種組合。

我的推薦用2,3兩種方式,不建議將class放入controller scope之上,scope須要保持純潔行,scope上的只能是數據和行爲。

今天總結到此結束,有不對的地方望你們多多指出哦。讓咱們一塊兒進步。學習愉快!麼麼噠。。。。。。

相關文章
相關標籤/搜索