Ionic 2基礎(chǔ)小結(jié)

架構(gòu)總覽

Ionic 2是基于Angular 2的,在它基礎(chǔ)上封裝了許多mobile常用組件冰蘑。如果說Angular是一塊塊不同布料的話和泌,Ionic 就是一件件不同的衣服,T恤祠肥、牛仔武氓、帽子、小內(nèi)內(nèi)仇箱,不同的組件搭配成一套县恕,就是一個(gè)完整的APP。一旦涉及到調(diào)用mobile底層傳感器剂桥,cordova就派上用場(chǎng)了弱睦,它是鏈接原生代碼和前端代碼的橋梁。如啟動(dòng)錄音渊额,調(diào)用GPS等等况木。


總體架構(gòu)圖

模塊

Ionic 2各個(gè)模塊之間是相對(duì)獨(dú)立的,各自管理自己模塊的數(shù)據(jù)旬迹、邏輯火惊、頁面、樣式奔垦。一個(gè)完整模塊由以下幾個(gè)文件組成:

html頁面

scss頁面樣式

ts頁面邏輯

//頁面標(biāo)記屹耐,用于頁面懶加載
@IonicPage() 
//組件配置
@Component({
  selector: 'page-home',
  templateUrl: 'home.html',
  providers: [BOCHttpProvider, UtilProvider]
})
//獲取頁面元素
@ViewChild('input') inputElm
//監(jiān)聽事件
@HostListener('keydown', ['$event'])
  keyEvent(e) {}

module.ts模塊管理

快速添加test模塊命令:ionic g page test

Provider

添加@Injectable()注解

  • 作為公共的方法類
  • 作為網(wǎng)絡(luò)數(shù)據(jù)源
  • 不同模塊之間邏輯協(xié)作的事務(wù)類
    快速添加命令:ionic g provider testProvider

Cordova插件

使用

  1. ionic自帶Native插件的使用
#添加組件
cordova plugin add splash-screen
#刪除組件
cordova plugin rm splash-screen
// 使用
import { SplashScreen } from '@ionic-native/splash-screen';

2.第三方組件的使用

#本地組件
cordova plugin add path/to/plugin
#github組件
cordova plugin add url.git

插件根目錄下plugin.xml定義的基本配置。js-module標(biāo)簽對(duì)應(yīng)的name會(huì)在全局注入變量椿猎,這里是MyPlugin惶岭。

<platform name = "android">
        <js-module name="MyPlugin" src="www/cordova-plugin-MyPlugin.js">
            <clobbers target="MyPlugin" />
        </js-module>
</platform>

在ts文件定義一個(gè)變量,就可以使用了犯眠。

declare var MyPlugin: any;

如果需要在應(yīng)用啟動(dòng)時(shí)調(diào)用按灶,記得判斷它的ready狀態(tài)。只用ready的時(shí)候筐咧,插件才能正常使用鸯旁。

platform.ready().then(() => MyPlugin.doSomethingWithPlugin(success, error, "MyClass", "MyFunction", ["param"]));

插件的方法可以在www目錄下的js文件中找到噪矛。

//插件www目錄下定義的與原始代碼通信的API
//使用
var exec = require('cordova/exec');

module.exports = {
    // success 成功回調(diào),error失敗回調(diào)铺罢, service類名艇挨, action方法名, params傳入數(shù)組參數(shù)
    doSomethingWithPlugin: function(success, error, service, action, params){
        // do something when resulting from native code
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末韭赘,一起剝皮案震驚了整個(gè)濱河市缩滨,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌泉瞻,老刑警劉巖脉漏,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異瓦灶,居然都是意外死亡鸠删,警方通過查閱死者的電腦和手機(jī)抱完,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門贼陶,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人巧娱,你說我怎么就攤上這事碉怔。” “怎么了禁添?”我有些...
    開封第一講書人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵撮胧,是天一觀的道長。 經(jīng)常有香客問我老翘,道長芹啥,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任铺峭,我火速辦了婚禮墓怀,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘卫键。我一直安慰自己傀履,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開白布莉炉。 她就那樣靜靜地躺著钓账,像睡著了一般。 火紅的嫁衣襯著肌膚如雪絮宁。 梳的紋絲不亂的頭發(fā)上梆暮,一...
    開封第一講書人閱讀 51,631評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音绍昂,去河邊找鬼惕蹄。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的卖陵。 我是一名探鬼主播遭顶,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼泪蔫!你這毒婦竟也來了棒旗?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤撩荣,失蹤者是張志新(化名)和其女友劉穎铣揉,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體餐曹,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡逛拱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了台猴。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片朽合。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖饱狂,靈堂內(nèi)的尸體忽然破棺而出曹步,到底是詐尸還是另有隱情,我是刑警寧澤休讳,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布讲婚,位于F島的核電站,受9級(jí)特大地震影響俊柔,放射性物質(zhì)發(fā)生泄漏筹麸。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一雏婶、第九天 我趴在偏房一處隱蔽的房頂上張望物赶。 院中可真熱鬧,春花似錦尚骄、人聲如沸块差。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽憨闰。三九已至,卻和暖如春需五,著一層夾襖步出監(jiān)牢的瞬間鹉动,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來泰國打工宏邮, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留泽示,地道東北人缸血。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像械筛,于是被迫代替她去往敵國和親捎泻。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Ionic是一個(gè)基于Angular2的開發(fā)手機(jī)web app的框架埋哟,它包含了一整套手機(jī)端的樣式組件笆豁,和一系列的功能...
    王兆龍閱讀 1,179評(píng)論 1 1
  • 0 開始之前 通過本教程之前,您應(yīng)該至少了解一些基本的Ionic 2概念。您還必須已經(jīng)安裝了Ionic 2 在您的...
    孫亖閱讀 1,653評(píng)論 2 10
  • ionic是一個(gè)運(yùn)行在webview上的應(yīng)用赤赊,但是很多功能js搞不定闯狱,免不了本地代碼的支持。ionic在nativ...
    李澤1988閱讀 3,043評(píng)論 0 3
  • 前言:用cordova開發(fā)hybrid app的過程中抛计,由于是html5開發(fā)的app哄孤,在手機(jī)上很多權(quán)限受限制...
    京東內(nèi)部?jī)?yōu)惠券閱讀 5,383評(píng)論 5 65
  • 五個(gè)題目 為你寫詩 我把春天寫給你 如果云知道 追尋 千年之戀 追尋 文/昕若初 我在夢(mèng)里追尋你的腳步 追了許多許...
    昕若初閱讀 190評(píng)論 2 0