很多人在問我是 ionic好呢?還是react好呢? 其實我只想告訴你去看文檔啊,不用用怎么知道哪個合適呢? 嘿嘿但是真的這么問的時候我也不會這么回答的,那豈不是太張狂了哈哈哈
成都創新互聯服務項目包括江華網站建設、江華網站制作、江華網頁制作以及江華網絡營銷策劃等。多年來,我們專注于互聯網行業,利用自身積累的技術優勢、行業經驗、深度合作伙伴關系等,向廣大中小型企業、政府機構等提供互聯網行業的解決方案,江華網站推廣取得了明顯的社會效益與經濟效益。目前,我們服務的客戶以成都為中心已經輻射到江華省份的部分城市,未來相信會繼續擴大服務區域并繼續獲得客戶的支持與信任!react我確實沒有用過,所以今天不多做什么評價。但是ionic我在項目中一直用著,想說的是確實很好用。
上一篇文章我們介紹了css3實現聊天界面的布局。那么今天我們就來學習一下,如何在頁面進行數據交互。
文章重點:
如何在頁面巧妙的運用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
在angular中為我們提供了3種方案處理class:
:scope變量綁定,如上例。(不推薦使用)
:字符串數組形式。
:對象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上的只能是數據和行為。
今天總結到此結束,有不對的地方望大家多多指出哦。讓我們一起進步。學習愉快!么么噠。。。。。。
另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
分享文章:Ionic的ng-class在聊天功能上面的巧妙運用-創新互聯
標題URL:http://vcdvsql.cn/article32/ceeosc.html
成都網站建設公司_創新互聯,為您提供做網站、網站收錄、用戶體驗、網站維護、自適應網站、網站排名
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯