中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

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

發布時間:2020-06-29 12:49:39 來源:網絡 閱讀:759 作者:VIP_web 欄目:開發技術

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

react我確實沒有用過,所以今天不多做什么評價。但是ionic我在項目中一直用著,想說的是確實很好用。

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

文章重點:

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

  2. ng-class有哪些使用方法

接下來我們就圍繞以上的重點來講述:

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

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

HTML

<!-- 聊天界面 -->
 <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

第二、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上的只能是數據和行為。

今天總結到此結束,有不對的地方望大家多多指出哦。讓我們一起進步。學習愉快!么么噠。。。。。。


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

灵璧县| 新田县| 惠安县| 竹溪县| 定结县| 田林县| 黑龙江省| 密云县| 佛山市| 淮南市| 德钦县| 高平市| 宁都县| 南溪县| 游戏| 葫芦岛市| 西充县| 蒲江县| 盈江县| 民丰县| 合水县| 山阳县| 宜州市| 钟山县| 诸暨市| 云林县| 克拉玛依市| 滦南县| 唐山市| 桂平市| 杭锦后旗| 栾城县| 白玉县| 邳州市| 麻江县| 成武县| 赞皇县| 修水县| 梁河县| 容城县| 宜黄县|