APP開發(fā)從入門到精通(app開發(fā)教程入門到精通)
可能很多人不知道,規(guī)模大的企業(yè)和IT預(yù)算多的企業(yè)的移動App大部分都是基于混合模式開發(fā)實(shí)現(xiàn)的。
很多做App開發(fā)的技術(shù)人員會存在一種偏見,覺得“采用混合模式,基于HTML5技術(shù)開發(fā)出來的App,體驗(yàn)以及功能會和原生模式開發(fā)的存在差距”,所以更愿意使用原生模式開發(fā)App。
其實(shí)市場上主流的App,絕大部分是基于混合模式開發(fā)的。最典型的就是微信,除了聊天功能以外,包括公眾號、小程序等都是由混合模式開發(fā)技術(shù)實(shí)現(xiàn)的。再比如電商領(lǐng)域的淘寶、京東等,旅游領(lǐng)域的攜程,教育領(lǐng)域的VipKid,信息分類的58等不同應(yīng)用范圍的App,混合模式開發(fā)技術(shù)使其商品展示及線上市場活動的運(yùn)營管理都變得非常靈活。此外,在航空、保險(xiǎn)、銀行等行業(yè)中,無論是服務(wù)客戶的toC模式App,還是對員工進(jìn)行管理的toE和toB的App,多是使用混合模式開發(fā)的,混合模式開發(fā)技術(shù)成為了絕對主力。
人們不禁要問“為什么這些公司和企事業(yè)單位,有著足夠的預(yù)算和開發(fā)資源,還要選擇混合模式App開發(fā)技術(shù)作為企業(yè)互聯(lián)網(wǎng)化的支撐?”答案其實(shí)和企業(yè)的互聯(lián)網(wǎng)化及數(shù)字化的需求有著直接的聯(lián)系。以下4個方面,決定了越有實(shí)力的企業(yè)越需要混合模式App開發(fā)技術(shù);同時,也是混合模式App開發(fā)技術(shù)形成不同行業(yè)解決方案的根本優(yōu)勢和企業(yè)選擇的必要性所在。
速度的要求
“試錯”這個詞不但在互聯(lián)網(wǎng)公司中廣為流傳,在傳統(tǒng)公司的互聯(lián)網(wǎng)化過程中也被廣泛接受。
越來越多的CIO在談各自企業(yè)移動戰(zhàn)略的時候,都會提到“能否根據(jù)業(yè)務(wù)部門的一個想法,先在一周之內(nèi)做個原型,快速實(shí)現(xiàn),拿出去讓大家看看,然后基于這個原型再修改”。這種快速發(fā)起、快速驗(yàn)證、快速調(diào)整的方法,已經(jīng)非常流行。之所以要在短時間內(nèi)先把業(yè)務(wù)從想法落到現(xiàn)實(shí),哪怕App粗糙些,也要先實(shí)現(xiàn)出來,原因在于具有鮮明企業(yè)個性的業(yè)務(wù)的創(chuàng)新想法可能沒有先例可循,很難考慮得特別完整。與其花費(fèi)三五個月不停地思考業(yè)務(wù)需求,還不如用一兩個星期先把基礎(chǔ)的想法落實(shí)。哪怕短時間內(nèi)做出的App并不能真正滿足業(yè)務(wù)的需要,但是可以讓業(yè)務(wù)人員的想法在這個過程中變得有據(jù)可依、有的放矢,從而為實(shí)現(xiàn)更完整且更切實(shí)可行的業(yè)務(wù)方案先行探索。
“業(yè)務(wù)部門的一個想法,IT部門一兩周就做出來了!”這對于企業(yè)的信息化負(fù)責(zé)人而言,是很重要的褒獎。這種對速度的要求,恰恰是混合模式開發(fā)技術(shù)最明顯的特長和優(yōu)勢,一套代碼可同步生成iOS與Android兩個平臺的App,甚至還能部分兼容微信公眾號和小程序。一套代碼,并不代表偷懶或工程技術(shù)的簡化,而更多的是因其不僅節(jié)省了代碼編寫的時間,還避免了多個技術(shù)團(tuán)隊(duì)之間跨知識結(jié)構(gòu)的協(xié)同問題,不再需要iOS與Android工程師們開會討論差異性問題,更是大幅節(jié)省了App與服務(wù)器端聯(lián)機(jī)調(diào)試的時間成本。但如果同樣的功能,同樣從零開始,使用傳統(tǒng)的原生開發(fā)技術(shù)基本沒有辦法在一兩個星期內(nèi)完成有價(jià)值業(yè)務(wù)需求的實(shí)現(xiàn),因?yàn)檫@個時間可能連不同終端碎片化和差異化的問題都不足以解決。所以,CIO為了滿足業(yè)務(wù)發(fā)展的需求和數(shù)字化速度的要求,在移動戰(zhàn)略中往往都會規(guī)劃使用跨平臺的混合模式App開發(fā)技術(shù)。
業(yè)務(wù)靈活性的要求
在PC時代的B/S架構(gòu)中,想要實(shí)現(xiàn)IT系統(tǒng)的更新并不需要過多地考慮用戶端的影響。因?yàn)樽鳛橛脩羧肟诘臑g覽器一直處于訪問網(wǎng)絡(luò)的狀態(tài),只要網(wǎng)絡(luò)連通,用戶隨時訪問網(wǎng)站都會獲得最新的功能和業(yè)務(wù)。對用戶而言,并不真正地存在版本的概念。只要訪問服務(wù)器,服務(wù)器的任何更新都可以隨時展示到用戶界面上,出現(xiàn)使用問題時,往往只需要清空一次瀏覽器Cookie基本就可以解決。
但是在移動時代,用戶對版本的概念變得越發(fā)敏感。而對App的版本管理也成了CIO頭痛的問題。通常因?yàn)檐浖_發(fā)商能力的制約,或者一些無法避免的bug,讓一些已發(fā)布的App變得難用甚至?xí)罎ⅰ4送?,一些臨時的市場活動、很少但重要的功能、一些不在規(guī)劃內(nèi)的產(chǎn)品需求調(diào)整等情況,都會直接引出同一個問題“用戶必須更新一個版本,重新下載安裝,才能滿足上述需求”。這種看似日常的版本發(fā)布和用戶更新,恰恰是傳統(tǒng)企業(yè)信息化過程中面臨的全新問題。
“能否像傳統(tǒng)瀏覽器那樣,用戶打開的永遠(yuǎn)是最新的服務(wù)和功能?”很多企業(yè)的CIO問出了相同的問題,于是大量的、不合規(guī)的軟件服務(wù)商和IT程序員想出了一個“偷懶”的模式。在App中嵌入一些WebView,將一些功能采用傳統(tǒng)網(wǎng)頁的模式,訪問服務(wù)器,動態(tài)獲取。雖然表面上解決了版本更新的問題,實(shí)則產(chǎn)生了大量體驗(yàn)很差的App。
企業(yè)對業(yè)務(wù)靈活性的要求,本質(zhì)是希望像微信小程序一樣,可以隨時發(fā)布一些新的功能,隨時動態(tài)增改一些功能的入口,讓用戶任意使用,同時讓用戶的體驗(yàn)更好。這種對業(yè)務(wù)靈活性的需求其實(shí)需要像小程序一樣有強(qiáng)大的混合模式App開發(fā)技術(shù)來支撐。從而達(dá)成“增量更新”“靜默更新”“打開獲得新功能和新體驗(yàn)”,而不是嵌套WebView,用網(wǎng)頁模擬App的方法,以較差的用戶體驗(yàn)的代價(jià)換取業(yè)務(wù)靈活的可行性。
當(dāng)然,目前傳統(tǒng)模式開發(fā)的App,特別是用Android開發(fā)的App也開始部分支持動態(tài)更新。這也恰恰說明,業(yè)務(wù)靈活性是企業(yè)互聯(lián)網(wǎng)化、數(shù)字化進(jìn)程的剛需。只是由于傳統(tǒng)技術(shù)的制約以及軟件開發(fā)團(tuán)隊(duì)或者服務(wù)商能力的限制,真正的原生動態(tài)更新始終沒有辦法大規(guī)模進(jìn)入企業(yè),實(shí)現(xiàn)商用。這也讓企業(yè)對混合模式App開發(fā)技術(shù)的需求更為迫切,成為每個CIO的必備選項(xiàng)。
集中管理的要求
業(yè)務(wù)部門的互聯(lián)網(wǎng)化意識是因?yàn)榛ヂ?lián)網(wǎng)的廣泛普及被帶動起來的。所以,傳統(tǒng)的由IT部門主導(dǎo)企業(yè)信息化的態(tài)勢發(fā)生了微妙的變化。過去,都是由IT部門發(fā)起信息化需求,但現(xiàn)在的IT部門越來越像“服務(wù)部門”。因?yàn)闃I(yè)務(wù)團(tuán)隊(duì)在不停地發(fā)起各種各樣“業(yè)務(wù) 互聯(lián)網(wǎng)”的信息化需求。這個時候,很多傳統(tǒng)企業(yè)的IT部門領(lǐng)導(dǎo),沒認(rèn)識到自己角色的轉(zhuǎn)變,如果還存有拖延、不管不問、你們自己搞不定等類似的想法,就會導(dǎo)致當(dāng)下很多企業(yè)的信息化面臨的“各種移動App的徹底碎片化”“各個業(yè)務(wù)部門自己找軟件開發(fā)商實(shí)現(xiàn)各自的需求”等問題。這不但架空了IT部門的信息化主導(dǎo)地位,更麻煩的是,讓后續(xù)的集中管理變得艱難無比。幾十家甚至上百家不同標(biāo)準(zhǔn)的服務(wù)摻雜在企業(yè)的核心系統(tǒng)中,甚至有些業(yè)務(wù)部門為了快速滿足自己的需求而脫離了IT部門主導(dǎo)的傳統(tǒng)PC核心系統(tǒng),這些操作都是非常危險(xiǎn)的。
IT部門在被業(yè)務(wù)部門要求滿足業(yè)務(wù)的互聯(lián)網(wǎng)化需求時,往往發(fā)現(xiàn)心有余而力不足。IT部門人手有限,實(shí)在沒辦法逐一滿足所有業(yè)務(wù)部門的移動化需求。如果不管,就會產(chǎn)生前面所提到的“技術(shù)棧、開發(fā)商”碎片化的問題。這個時候,基于混合模式App開發(fā)技術(shù)的移動應(yīng)用平臺,就很好地解決了這二者之間的矛盾。
定標(biāo)準(zhǔn),從而實(shí)現(xiàn)“集中管理”。如果企業(yè)能夠制訂一套統(tǒng)一的混合模式App開發(fā)技術(shù)和移動平臺標(biāo)準(zhǔn),各個業(yè)務(wù)部門就可以獨(dú)立尋找自己的軟件開發(fā)商,用各種方法滿足自己的移動業(yè)務(wù)需求。平臺的一致性可以帶來標(biāo)準(zhǔn)化的統(tǒng)一。這其中包括技術(shù)標(biāo)準(zhǔn)化、開發(fā)流程標(biāo)準(zhǔn)化、代碼管理標(biāo)準(zhǔn)化、項(xiàng)目管理標(biāo)準(zhǔn)化、驗(yàn)收標(biāo)準(zhǔn)化、管理和運(yùn)營標(biāo)準(zhǔn)化等。
既要放,也要抓。這就是互聯(lián)網(wǎng)時代企業(yè)信息化的要求,更是IT部門的職責(zé)?;旌夏J紸pp開發(fā)技術(shù),有望成為實(shí)現(xiàn)企業(yè)移動戰(zhàn)略的利器之一。
信息化安全的要求
企業(yè)互聯(lián)網(wǎng)化帶來的最根本轉(zhuǎn)變就是,內(nèi)網(wǎng)的信息化變成了外網(wǎng)的互聯(lián)網(wǎng)化。
傳統(tǒng)信息化一般包括內(nèi)網(wǎng)、固定場所、固定網(wǎng)絡(luò)環(huán)境和固定的設(shè)備等關(guān)鍵詞。而移動戰(zhàn)略背景下的企業(yè)互聯(lián)網(wǎng)化,則同時包括外網(wǎng)、隨時、隨地、員工個人設(shè)備、4G和Wi-Fi等關(guān)鍵詞。這些不起眼的變化,給企業(yè)的業(yè)務(wù)帶來的卻是天翻地覆的調(diào)整。
移動設(shè)備管理軟件(Mobile Devices Management,MDM)曾風(fēng)靡一時,但是購買了MDM的企業(yè)幾乎無一例外地發(fā)現(xiàn)其很難推進(jìn)。因?yàn)镸DM伴隨著員工自帶設(shè)備(Bring Your Own Device,BYOD)。如果用企業(yè)的管理軟件來管理員工個人設(shè)備,肯定會有很多人反對。所以,大部分的MDM最終草草收場,只是管理了企業(yè)自己購買的一些移動設(shè)備。
企業(yè)移動化、互聯(lián)網(wǎng)化的安全怎么保障? 這要滿足3個層面的安全,即設(shè)備安全、傳統(tǒng)安全和云端安全。
混合模式App開發(fā)技術(shù)可以實(shí)現(xiàn)類似于企業(yè)應(yīng)用商店(如微信公眾號)的動態(tài)權(quán)限綁定和授權(quán)模式,能夠支持特定設(shè)備、特定的人,也可以選擇不同的子應(yīng)用。此外,還可以實(shí)現(xiàn)隨著用戶工作內(nèi)容的調(diào)整,根據(jù)設(shè)備編碼和用戶權(quán)限來實(shí)時分配全新子應(yīng)用的功能。
這種基于企業(yè)移動應(yīng)用商店的“子應(yīng)用”模式,也是混合模式App開發(fā)技術(shù)成為企業(yè)移動戰(zhàn)略支撐的關(guān)鍵。因?yàn)樽龅煤玫钠髽I(yè)應(yīng)用商店,不僅能夠滿足傳統(tǒng)原生模式開發(fā)的App所不能賦予企業(yè)的、對各種安全性的需求,還實(shí)現(xiàn)了對業(yè)務(wù)靈活性的管理目的。
APICloud作為中國主流的混合模式App開發(fā)技術(shù)服務(wù)提供商,一直在以布道者的身份推進(jìn)混合技術(shù)在國內(nèi)的發(fā)展和應(yīng)用。我們不僅提供技術(shù),也提供商業(yè)服務(wù),因此會更多地深入到大量的商業(yè)用戶中去,如海爾、春秋航空、英特爾、中信證券、上汽等。我們的團(tuán)隊(duì)結(jié)合不同的商業(yè)場景和實(shí)際的商業(yè)客戶需求,編寫了《30天App開發(fā)從0到1:APICloud移動開發(fā)實(shí)戰(zhàn)》,希望能夠?yàn)椴煌?guī)模的企業(yè)在移動信息化和互聯(lián)網(wǎng)化進(jìn)程中提供有價(jià)值的參考,同時也能夠讓從事App開發(fā)的技術(shù)人員有更多可借鑒的實(shí)戰(zhàn)經(jīng)驗(yàn)。
?
《30天App開發(fā)從0到1:APICloud移動開發(fā)實(shí)戰(zhàn)》
鄒達(dá), 李德興 著
主要內(nèi)容
本文從總體上介紹APICloud平臺,包括APICloud應(yīng)用的開發(fā)模式、設(shè)計(jì)思想、控制臺使用流程等,并以一個HelloWorld App為例讓讀者體驗(yàn)一個完整的APICloud App的開發(fā)流程。
學(xué)習(xí)目標(biāo)
(1)了解APICloud平臺,了解APICloud相關(guān)的學(xué)習(xí)資源、入門資料和常見的問題。讓沒有接觸過APICloud平臺的讀者,對平臺有一個基礎(chǔ)的了解;讓學(xué)習(xí)過APICloud并且已掌握一部分技能的讀者,通過本文的學(xué)習(xí),可以快速找到需要的資料和解決問題的方法。
(2)學(xué)習(xí)如何在APICloud平臺上創(chuàng)建、修改、調(diào)試、編譯和運(yùn)行一個最簡單的APICloud App。掌握APICloud App完整的開發(fā)流程。
要對APICloud平臺做一個全面的介紹,需要花很長的時間和很多的篇幅來講解每一個細(xì)節(jié),而本文作者希望能用更多的篇幅來講解一個App的實(shí)際開發(fā)過程,講解具體的代碼實(shí)現(xiàn)。所以,本文在介紹APICloud平臺的時候,是通過拋出一個個問題,然后告訴讀者應(yīng)該到哪兒去找對應(yīng)的學(xué)習(xí)資源,到哪兒能夠找到解決問題的方案。
1.1 APICloud平臺介紹
本文將從APICloud可以做什么,如何獲取使用幫助,APICloud的技術(shù)、產(chǎn)品和生態(tài)等多個方面對APICloud平臺加以介紹。
1.1.1 查看APICloud平臺能力
開發(fā)者在接觸一個開發(fā)平臺的時候,通常第一個想法就是去查看這個平臺的能力。特別是那些想做App的、有著明確需求的開發(fā)者,他們會非常關(guān)心自己的需求在這個開發(fā)平臺上是否能夠滿足。所以,本文開篇就先來解決這個開發(fā)者普遍關(guān)心的問題,讀者可以帶著自己預(yù)先想好的需求來了解APICloud平臺,了解如何能夠快速地在APICloud平臺上查找相關(guān)的能力。
1.通過官方文檔快速搜索功能模塊
查看APICloud平臺提供的能力,一個最基礎(chǔ)也是最有效的方法就是查看APICloud的API文檔。
APICloud官方網(wǎng)站中的文檔頁面如圖1-1所示。如需要查看視頻播放的功能,可以在文檔中搜索“視頻播放”,搜索結(jié)果如圖1-2所示,可以看到在APICloud平臺上有多種提供視頻播放功能的模塊,如videoPlayer(播放本地視頻)、moviePlayer(播放網(wǎng)絡(luò)視頻)、polyvPlayer(保利威視播放器)、baiduPlayer(百度播放器)等。
?
圖1-1 ?
圖1-2
點(diǎn)擊其中一個搜索結(jié)果,查看模塊的詳細(xì)文檔。比如點(diǎn)擊“videoPlayer”之后可以看到這個模塊對于視頻播放提供了很多API,這些API基本覆蓋了一個視頻播放器所有常見的功能,如圖1-3所示。
?
圖1-3
再比如要查找支付功能,可以在文檔中搜索“支付”,通過搜索結(jié)果可以看到在APICloud平臺上有很多個提供支付功能的模塊,如aliPay(支付寶)、wxPay(微信支付)、unionPay(銀聯(lián)支付)、paypal(PayPal支付)、iap(iOS應(yīng)用內(nèi)支付)等;也有ping 、beeCloud等第三方聚合類的支付模塊。點(diǎn)擊每個模塊均可以查看具體的API詳情。
讀者想了解APICloud平臺有哪些能力,最簡單的方法就是到APICloud官方文檔中去搜索相應(yīng)的功能,這樣就可以一目了然地知道APICloud平臺有沒有相應(yīng)的模塊來支持自己想要的功能。
2. APICloud能力支撐體系
目前在APICloud平臺上已經(jīng)提供了600多個模塊,上萬個API。這些API基本可以覆蓋一款A(yù)pp所需的所有常用功能,為方便表述,它們被分為“平臺使用”“基礎(chǔ)功能”“界面布局”“設(shè)備特性”“功能擴(kuò)展”和“開放服務(wù)”六大類,其分類與具體包含內(nèi)容如圖1-4所示。
?
圖1-4
1.1.2 開發(fā)模式、技術(shù)語言和平臺定位
很多APICloud初學(xué)者會關(guān)心這些問題:APICloud App的開發(fā)模式是什么樣的、使用什么技術(shù)語言、目前自己的開發(fā)團(tuán)隊(duì)是否適合使用APICloud開發(fā)App、整個APICloud的學(xué)習(xí)曲線是什么樣的、入門簡不簡單等。
1.開發(fā)模式和技術(shù)語言
APICloud應(yīng)用的開發(fā)模式是使用標(biāo)準(zhǔn)的HTML、CSS和JavaScript APICloud擴(kuò)展API來進(jìn)行App開發(fā),如圖1-5所示。APICloud的App開發(fā)使用的是標(biāo)準(zhǔn)的HTML5技術(shù),針對標(biāo)準(zhǔn)HTML5所不具備的功能或是用HTML5實(shí)現(xiàn)體驗(yàn)不好的功能(這些功能也是開發(fā)者在App開發(fā)過程中非常常用的功能)。APICloud提供了600多個擴(kuò)展模塊和上萬個API,通過這些模塊和API來擴(kuò)展HTML5的功能,滿足App的開發(fā)需求。
?
圖1-5
2.?dāng)U展API調(diào)用方式
APICloud擴(kuò)展API的調(diào)用方式與調(diào)用標(biāo)準(zhǔn)的JavaScript方法是完全一樣的。APICloud引擎的核心API是放在window.api這個對象下面的,這個對象是APICloud在JavaScript全局作用域內(nèi)擴(kuò)展的唯一一個對象,可直接調(diào)用。如果想調(diào)用某個模塊下面的方法,可以通過require的方式動態(tài)引入,通過在api.require方法的參數(shù)中指定某個模塊的名稱來引入相應(yīng)的模塊,然后調(diào)用模塊下面的方法,具體演示如下。
1 //核心API在window.api對象下,可以直接調(diào)用 2 api.methodName(param, callback); 3 //擴(kuò)展模塊需要require引入,遵守CommonJS規(guī)范 4 var module = api.require(‘moduleName’); 5 module.methodName(param, callback); 6 param: {} //參數(shù),是一個JSON對象 7 callback: function(ret, err){} //回調(diào)函數(shù),是一個Function對象,異步方法調(diào)用的結(jié)果通過此函數(shù)返回<br>
所有API的調(diào)用方式都是相同的,第一個參數(shù)是一個JSON對象,承載著要傳遞給模塊的信息;第二個參數(shù)是一個callback函數(shù)。APICloud大部分的API調(diào)用都是異步方式,在調(diào)用的時候,要指定一個callback函數(shù),當(dāng)這個API操作完成時,操作結(jié)果將通過該callback函數(shù)回調(diào)。
一些常用的調(diào)用方式,比如打開一個新窗口,可以調(diào)用api.openWin();打開通訊錄可以調(diào)用api.openContacts(),錄音、圖片緩存等也是調(diào)用相應(yīng)的方法。如果想去加載文件系統(tǒng)模塊,可以通過api.require(“fs”)來加載fs模塊,然后調(diào)用fs模塊下面的方法。使用條碼掃描模塊也是類似的。示例如下。
●打開新窗口:api.openWin()。
●打開系統(tǒng)通訊錄:api.openContacts()。
●錄音:api.startRecord()。
●緩存網(wǎng)絡(luò)圖片:api.imageCache()。
●加載fs模塊:var fs = api.require(‘fs’)。
●新建一個文件:fs.createFile()。
●加載二維碼/條形碼掃描模塊:var scanner = api.require(‘FNScanner’)。
●打開二維碼/條形碼掃描:scanner.openScanner()。
APICloud技術(shù)是基于標(biāo)準(zhǔn)的HTML、CSS和JavaScript技術(shù),并在標(biāo)準(zhǔn)的JavaScript基礎(chǔ)上擴(kuò)展了一個核心對象-api對象和數(shù)百個模塊。這些模塊可以使用api.require函數(shù)載入,并使用操作標(biāo)準(zhǔn)JavaScript對象的方式調(diào)用上述模塊列舉出方法。
3.?dāng)U展API的作用
讀者可能會問,APICloud為什么要擴(kuò)展這么多API呢?其實(shí)APICloud所擴(kuò)展的API都是標(biāo)準(zhǔn)的JavaScript所不支持的方法,或是用標(biāo)準(zhǔn)HTML5來實(shí)現(xiàn)但體驗(yàn)不好的功能。讀者可以把HTML5理解成一門技術(shù)、一門語言,但是它還沒有達(dá)到一個平臺的水平。這就是APICloud為什么要做這些擴(kuò)展。APICloud所有的擴(kuò)展主要是圍繞以下這4個方面進(jìn)行的。
兼容性:在PC互聯(lián)網(wǎng)時代,瀏覽器具有多種內(nèi)核,JavaScript框架產(chǎn)生的最初原因就是為了實(shí)現(xiàn)JavaScript代碼在各種瀏覽器上的兼容和適配。在移動互聯(lián)網(wǎng)時代,雖然在主流的手機(jī)系統(tǒng)中,Android和iOS的瀏覽器內(nèi)核都是webkit,但是出于商業(yè)原因,谷歌從webkit中建立了一個新的分支,叫blink?,F(xiàn)在兩個分支的主要貢獻(xiàn)者分別是蘋果和谷歌,所以未來這兩個內(nèi)核的兼容性問題會一直存在。
實(shí)用性:
Page不等于App,標(biāo)準(zhǔn)的HTML、CSS和JavaScript規(guī)范更多是用來定義網(wǎng)頁和文檔的,例如現(xiàn)在的一些框架都在講SPA結(jié)構(gòu),它是以單頁面為主的,很多HTML標(biāo)簽是針對于文本信息展示的;而App則不然,App更多是強(qiáng)調(diào)功能和體驗(yàn),在原生系統(tǒng)中有很多的組件,HTML5標(biāo)簽和Native組件的設(shè)計(jì)規(guī)范是完全不同的。所以,想用標(biāo)準(zhǔn)的HTML5技術(shù)開發(fā)一個App是不現(xiàn)實(shí)的,人們不能直接把為WebPage所制定的規(guī)范直接搬到App上。
B/S架構(gòu)與Client/Cloud架構(gòu):在PC互聯(lián)網(wǎng)時代,終端產(chǎn)品的主要架構(gòu)還是B/S架構(gòu);但是在移動互聯(lián)網(wǎng)時代,終端產(chǎn)品的主要類型是App,而App是一個完整的Client/Cloud架構(gòu)。在移動端,實(shí)現(xiàn)界面和功能,在云端提供數(shù)據(jù)和服務(wù)。頁面布局是存放在移動端的,功能實(shí)現(xiàn)也是在移動端完成,所以用戶在使用時可以感受到App的啟動、頁面渲染和布局展示是很快響應(yīng)的。
速度、交互和體驗(yàn):這3個問題是用HTML5技術(shù)直接開發(fā)App的最大挑戰(zhàn)。其實(shí),如果使用HTML5技術(shù)實(shí)現(xiàn)一個界面,渲染之后顯示出來,用戶看到這個界面時并不能立刻分辨出它是用HTML5實(shí)現(xiàn)的還是用Native技術(shù)實(shí)現(xiàn)的。但是當(dāng)用戶做一個交互,點(diǎn)擊一下,體驗(yàn)一下響應(yīng)速度或者做一個手勢,觸發(fā)一個動畫,這時用戶就可以非常清楚地感受到,并能分辨出該界面是用Native技術(shù)開發(fā)的還是用HTML5開發(fā)的。所以速度、交互和體驗(yàn)也是使用HTML5技術(shù)開發(fā)App必須去解決的問題。
持續(xù)性、靜態(tài)標(biāo)準(zhǔn)與動態(tài)標(biāo)準(zhǔn):HTML5的定稿花了7年時間,并且整個標(biāo)準(zhǔn)的迭代是緩慢的;而Android和iOS每一次版本更新都會新增很多功能,這些新增的恰恰都是當(dāng)前行業(yè)里最需要的功能,但這些功能很難快速通過制定新的HTML5標(biāo)準(zhǔn)進(jìn)行更新,并在各個瀏覽器里支持起來。那會是一個非常漫長的過程。
擴(kuò)展性:在開發(fā)一款A(yù)pp的時候,開發(fā)人員需要擴(kuò)展很多的功能,有時候要和行業(yè)特點(diǎn)結(jié)合,有時候還要跟硬件結(jié)合,這就會用到大量國內(nèi)的開放服務(wù),如推送、直播、智能識別等。所有的這些功能,標(biāo)準(zhǔn)的HTML5規(guī)范中都沒有定義,所有的標(biāo)準(zhǔn)瀏覽器引擎也沒有默認(rèn)支持。
總的來說,APICloud擴(kuò)展的所有功能都是標(biāo)準(zhǔn)HTML5所沒有的,如果HTML5有并且在App中運(yùn)行起來沒有任何問題,APICloud平臺也沒有必要去做這個擴(kuò)展。APICloud所有擴(kuò)展的功能其實(shí)就是為了去解決HTML5在兼容性、實(shí)用性、持續(xù)性和擴(kuò)展性等方面的問題。
4.模塊Store
在APICloud模塊Store中可以查看APICloud平臺擴(kuò)展的所有功能,如圖1-6所示。
?
?? 圖1-6
5. APICloud平臺定位
APICloud是一個中間層,是在應(yīng)用程序和系統(tǒng)之間的一層,在這一層中,APICloud聚合了開發(fā)一款A(yù)pp所需要的所有系統(tǒng)調(diào)用、開放服務(wù)和擴(kuò)展功能,然后以統(tǒng)一API的形式提供給開發(fā)者調(diào)用。這就是APICloud平臺的定位,如圖1-7所示。
?
?? 圖1-7
1.1.3 技術(shù)、產(chǎn)品、生態(tài)、案例和商業(yè)模式
這部分有大量的內(nèi)容需要給讀者介紹,但是本文不想為此占用大量的篇幅。讀者可以通過APICloud官網(wǎng)公開課的視頻來詳細(xì)了解。在官方視頻教程2中有幾百集的課程,其中“APICloud視頻之初級代碼篇第1~3講”通過幾小時的視頻給讀者詳細(xì)介紹了APICloud技術(shù)、產(chǎn)品、商業(yè)模式、案例以及生態(tài)的方方面面,如果讀者是第一次接觸APICloud,我們建議花一定的時間去觀看這些公開課的視頻。
在官方網(wǎng)站中,“開發(fā)者社區(qū)”標(biāo)簽下。
在官方的視頻教程中。
1.1.4 開發(fā)者服務(wù)體系
開發(fā)者在選擇或者使用一個平臺的時候,一定會遇到很多的問題。遇到問題時應(yīng)該如何解決?此外,開發(fā)者還會關(guān)心這個平臺在提供技術(shù)的同時還能提供哪些服務(wù)?有沒有一個完整的生態(tài)?有沒有一個活躍的社區(qū)提供技術(shù)支持、方便學(xué)習(xí)和交流?
針對這些問題,本節(jié)列舉以下APICloud開發(fā)者服務(wù)體系相關(guān)的產(chǎn)品。
1. APICloud開發(fā)平臺
這里是APICloud的官方網(wǎng)站,也是整個APICloud應(yīng)用開發(fā)和管理平臺的入口。
2.開發(fā)工具
在官方網(wǎng)站點(diǎn)擊“開發(fā)工具”。
APICloud是一個移動應(yīng)用的開發(fā)平臺,開發(fā)APICloud應(yīng)用需要編碼工具。對于開發(fā)工具來說,APICloud支持包括Atom、Sublime Text、Eclipse、WebStorm、VSCode,以及基于Node.js的CLI命令行工具。開發(fā)者在開發(fā)APICloud應(yīng)用的時候,可以使用自己喜歡的任意一款主流的編碼工具,只需要在這些工具中安裝相應(yīng)的APICloud插件就可以了。
以Sublime Text3為例,如圖1-8和圖1-9所示,可以看到這里面有Windows版和Mac版的下載地址,這里所下載的是APICloud為Sublime Text提供的插件。下載完成后,打開Sublime Text,在Sublime Text中安裝完APICloud插件之后,就可以在Sublime Text中使用“新建APICloud項(xiàng)目”“新建APICloud文件”“進(jìn)行Wifi真機(jī)同步”“日志輸出”“代碼管理”等開發(fā)APICloud應(yīng)用所需的相關(guān)功能。在其他工具中,如Atom、WebStorm、Eclipse和VSCode等也可以分別安裝APICloud為這些工具所提供的對應(yīng)插件,所有這些APICloud的工具插件都是免費(fèi)開源的,可以在GitHub的APICloud開源分支中查看源碼。
在GitHub中搜索“APICloud-DevTools”。
?
?? 圖1-8
本文案例的開發(fā)會全程使用APICloud Studio 2作為開發(fā)工具,APICloud Studio 2是APICloud提供給開發(fā)者的一款基于Atom擴(kuò)展的全功能集成開發(fā)工具。在本書的附錄B中,會對APICloud Studio 2開發(fā)工具的使用進(jìn)行全面詳細(xì)的介紹。
?
? 圖1-9
3.開發(fā)文檔
在官方網(wǎng)站點(diǎn)擊“文檔”。
整個APICloud開發(fā)文檔包含了3部分內(nèi)容,第一部分是對APICloud的整體介紹以及開發(fā)工具的介紹,也就是其網(wǎng)頁最左側(cè)的這一列;中間部分是對APICloud API的介紹,包括端API、擴(kuò)展模塊、前端框架、云API等;最右側(cè)是技術(shù)專題,這里會把開發(fā)過程中常見的問題以技術(shù)專題的形式總結(jié)出來。不管是對APICloud的初學(xué)者,還是已經(jīng)用APICloud開發(fā)過應(yīng)用的開發(fā)者,本文都建議在遇到問題的時候,第一個解決方式就是去查找文檔。APICloud文檔遵循簡潔清晰的書寫原則,用到某一個API的時候,直接到文檔中查看其對應(yīng)的使用說明即可。
4. 開發(fā)者社區(qū)
在官方網(wǎng)站點(diǎn)擊“開發(fā)者社區(qū)”。
APICloud有著國內(nèi)最活躍的HTML5混合開發(fā)者社區(qū),在這個社區(qū)中,有很多優(yōu)質(zhì)和資深的APICloud開發(fā)者,用戶在使用中遇到的問題在社區(qū)中提問都可以第一時間獲得解答。APICloud平臺上線至今,社區(qū)中已經(jīng)沉淀了很多有價(jià)值的帖子和技術(shù)專題的討論,所以非常建議開發(fā)者常去社區(qū)看看,那里的帖子都是各個開發(fā)者學(xué)習(xí)經(jīng)驗(yàn)的總結(jié)。本文希望讀者在開發(fā)過程中遇到問題的時候,可以到社區(qū)中查找相關(guān)的解答或者提問,初學(xué)者最好能花一些時間把新手入門的帖子從頭到尾看一遍,這是非常有價(jià)值的。
5. VIP服務(wù)
在官方網(wǎng)站點(diǎn)擊“VIP服務(wù)”。
很多大型企業(yè)或者創(chuàng)業(yè)公司在選擇APICloud的時候,由于整個項(xiàng)目的開發(fā)周期比較緊張,而剛剛接觸一個新的平臺,使用中會遇到一些問題,這些問題在社區(qū)中是可以得到解決的,但是可能不夠及時。針對這類客戶,APICloud提供了VIP技術(shù)支持服務(wù),企業(yè)也可以去購買APICloud企業(yè)版。當(dāng)然這個是收費(fèi)的,企業(yè)購買完之后,APICloud將以工單的形式提供技術(shù)支持,企業(yè)客戶有任何問題,半個小時之內(nèi)APICloud官方會有技術(shù)支持一對一地進(jìn)行解答。
6.開源代碼分享
點(diǎn)擊官方網(wǎng)站中“開發(fā)者社區(qū)”標(biāo)簽下面的源碼。
APICloud提供了非常豐富的開源代碼,這些源碼包括App實(shí)例源碼,很多都是APICloud開發(fā)者所開發(fā)的一些App模板源碼,也包括一些模塊的使用示例代碼,以及App開發(fā)過程中一些常用的JavsScript框架代碼。當(dāng)然,這里也有模塊的源碼,因?yàn)锳PICloud的很多模塊都是開源的,所以模塊的源碼就是Android和iOS的模塊工程源碼。同時,APICloud為Sublime Text、Atom、WebStorm、Eclipse等所有主流的開發(fā)工具提供的插件、命令行的CLI工具,以及APICloud Studio所有的代碼都是完全免費(fèi)開源的。
這里也有APICloud前端框架和官方文檔的源碼,APICloud官方文檔本身就是開源的。讀者如果發(fā)現(xiàn)官方文檔的編寫存在不夠準(zhǔn)確或者不夠完善的地方,可以隨時在官方文檔的開源分支中提交修改,一同為APICloud生態(tài)發(fā)展做貢獻(xiàn)。還有APICloud云SDK,也就是APICloud提供的云端服務(wù),官方提供了不同技術(shù)語言版本的SDK,包括Node.js、PHP、Java、.NET等,這些不同語言版本的云API SDK也都是開源的。
更多APICloud開源代碼可以到APICloud GitHub開源分支j查看。
j在GitHub中搜索“apicloudcom”。
7.商業(yè)案例展示
在官方網(wǎng)站點(diǎn)擊“開發(fā)案例”。
目前,基于APICloud平臺開發(fā)的應(yīng)用已有2萬多款在蘋果AppStore上線。在APICloud商業(yè)案例展示區(qū),用戶可以看到一些用APICloud開發(fā)出來的應(yīng)用案例,每期會展示數(shù)百款的已上線App,這些案例都是用APICloud開發(fā)的商用App,不是WebApp,也不是微信公眾號或HTML5網(wǎng)站。所有這些App旁邊都有二維碼,用戶可以直接掃碼安裝體驗(yàn),這些應(yīng)用都是使用APICloud平臺開發(fā)的。
如果APICloud的開發(fā)者開發(fā)了一款A(yù)pp,并且認(rèn)為其性能體驗(yàn)不錯,可以聯(lián)系A(chǔ)PICloud官方的運(yùn)營人員,申請?jiān)诠倬W(wǎng)展示這款A(yù)pp。APICloud可以在案例區(qū)為其免費(fèi)展示,案例區(qū)會定期更新申請展示的App。初學(xué)者如果想看一下APICloud平臺開發(fā)出來的App是什么樣的運(yùn)行體驗(yàn),就可以直接掃碼安裝運(yùn)行這些案例,看一下體驗(yàn)和效果。
8.模塊Store(聚合API)
點(diǎn)擊官方網(wǎng)站中,“App開發(fā)平臺”下面的模塊Store。
APICloud模塊Store上展示了APICloud平臺上所有的擴(kuò)展模塊。APICloud使用行業(yè)標(biāo)準(zhǔn)的模塊擴(kuò)展機(jī)制,對于具有Android和iOS開發(fā)經(jīng)驗(yàn)的開發(fā)者,可以直接按照APICloud模塊擴(kuò)展機(jī)制為APICloud貢獻(xiàn)模塊,這些模塊可以選擇收費(fèi)也可以免費(fèi)。
目前,APICloud平臺上有600多個模塊,大部分的模塊是免費(fèi)的。大約有1/3是APICloud官方開發(fā)的,官方提供的所有模塊都是免費(fèi)的,基本可以覆蓋App開發(fā)所需的全部基礎(chǔ)功能;還有1/3是第三方服務(wù)廠商開發(fā)的,比如高德地圖、科大訊飛語音識別、融云即時通訊等;最后的1/3是個人開發(fā)者開發(fā)的,個人開發(fā)者提供的模塊大部分都是收費(fèi)的。APICloud是想建立一個生態(tài),對于Android和iOS的開發(fā)者,可以非常輕松地為APICloud模塊Store貢獻(xiàn)模塊,同時模塊開發(fā)者可以為其開發(fā)的模塊標(biāo)一個價(jià)格,讓其他開發(fā)者購買后使用。
9.模板Store
點(diǎn)擊官方網(wǎng)站,“App定制服務(wù)”下面的模板Store。
APICloud還有一款產(chǎn)品是模板Store。開發(fā)者在開發(fā)完一個應(yīng)用之后,如果不想再運(yùn)營這個應(yīng)用了,或者是單純想做一款應(yīng)用的模板,如果它是一個完整的端到端的應(yīng)用,整個需求和功能都可以達(dá)到一個標(biāo)準(zhǔn)商業(yè)應(yīng)用的水平,就可以將它作為一個模板提交給APICloud。APICloud官方可以把它模板化后成為APICloud模板Store中的一款模板。整體是有一個審核流程的。模板審核通過之后,就可以在APICloud模板Store上進(jìn)行銷售。在模板Store上架后,其他開發(fā)者只需一鍵購買,在線支付,就可以在幾分鐘之內(nèi)獲得這樣一個模板。所購買的產(chǎn)品包括這個模板的管理后臺、模板的Android和iOS的安裝包以及一些必要的皮膚定制等服務(wù),同時在開發(fā)者的APICloud應(yīng)用控制臺中,也會有一個對應(yīng)的“模板應(yīng)用”的項(xiàng)目。
10. APICloud應(yīng)用定制服務(wù)
點(diǎn)擊官方網(wǎng)站中的“App定制服務(wù)”。
在APICloud平臺上每天都會聚集很多客戶的App定制需求,因?yàn)楹芏嗫蛻粽J(rèn)可APICloud平臺和App開發(fā)模式,但是由于沒有自己的開發(fā)團(tuán)隊(duì),所以希望APICloud能夠?yàn)樗麄兲峁〢pp定制服務(wù),或者為他們推薦優(yōu)質(zhì)的團(tuán)隊(duì)來進(jìn)行項(xiàng)目實(shí)施。APICloud應(yīng)用定制服務(wù)有一套標(biāo)準(zhǔn)化的開發(fā)流程和項(xiàng)目管理流程。
1.1.5 新手入門APICloud應(yīng)用開發(fā)
這里推薦一些優(yōu)質(zhì)的入門資料,讀者可以在官方文檔頁面中找到這些資料。
APICloud新手開發(fā)指南,在這個指南當(dāng)中,基本上涵蓋了APICloud應(yīng)用開發(fā)入門所需的各方面知識,并且APICloud官方也會不斷更新這個教程,所以這個新手開發(fā)指南是所有APICloud初學(xué)者必須要認(rèn)真閱讀的文檔。
APICloud新手教程集合貼,這是社區(qū)里的新手教程集合貼,里面有很多優(yōu)秀開發(fā)者的開發(fā)技巧、經(jīng)驗(yàn)和教程的總結(jié),推薦新手一定要看。
點(diǎn)擊官方網(wǎng)站中的“開發(fā)者社區(qū)”,搜索“新手教程集合貼”。
●APICloud視頻教程15,如果初學(xué)者想找一種更簡便的方式去學(xué)習(xí),也可以去看看APICloud的視頻教程,在這個視頻教程中已經(jīng)有數(shù)百集的視頻。
15點(diǎn)擊官方網(wǎng)站中的“視頻教程”。
●APICloud在線培訓(xùn),APICloud定期會舉辦線上的視頻直播培訓(xùn),直播的老師既有APICloud工程師,也有優(yōu)秀的APICloud開發(fā)者或其他培訓(xùn)機(jī)構(gòu)的老師來直播。
1.2 體驗(yàn)完整項(xiàng)目的開發(fā)流程
在對APICloud平臺有了基礎(chǔ)的認(rèn)識后,讀者將跟隨本節(jié)內(nèi)容從零開始,創(chuàng)建、修改、調(diào)試、編譯和運(yùn)行一個最簡單的App。這個App不包含任何復(fù)雜的開發(fā)技術(shù),旨在讓讀者體驗(yàn)一個完整App的開發(fā)流程。在本節(jié)的最后,這個應(yīng)用將可以在移動設(shè)備上運(yùn)行。
1.2.1 注冊APICloud賬號
在創(chuàng)建App項(xiàng)目之前,首先要有一個APICloud賬號,這個賬號非常重要,請妥善保管。點(diǎn)擊APICloud官方網(wǎng)站右上角的注冊按鈕即可開始注冊。注冊過程非常簡單,注冊完成后請登錄賬戶。
1.2.2 創(chuàng)建一個App項(xiàng)目
創(chuàng)建一個新的項(xiàng)目有兩種方式:
在APICloud云平臺上創(chuàng)建;
在APICloud的官方開發(fā)工具中創(chuàng)建。
APICloud推薦的集成開發(fā)工具是APICloud Studio 2。同時也為其他常用的開發(fā)工具軟件提供了插件支持,如Sublime、Eclipse、WebStorm、Atom等,讀者可以根據(jù)自己的使用習(xí)慣選擇對應(yīng)的工具。
本文以APICloud Studio 2為例。首先需要下載這個開發(fā)工具,選擇官網(wǎng)首頁的“App開發(fā)平臺”,然后選擇“開發(fā)工具”。
在新的頁面中根據(jù)具體的操作系統(tǒng)選擇對應(yīng)版本的APICloud Studio 2進(jìn)行下載。下載完成后將壓縮包解壓到任意位置,在解壓后的文件中找到類似“apicloud-studio-2.exe”的文件,這是開發(fā)工具的可執(zhí)行文件。建議為它創(chuàng)建桌面快捷方式以方便使用。
1.在APICloud云平臺上創(chuàng)建新項(xiàng)目
在官方網(wǎng)站登錄成功后,將鼠標(biāo)移動到頁面右上角的用戶名處,在顯示的菜單中點(diǎn)擊“開發(fā)控制臺”。
打開控制臺頁面后,頁面左側(cè)是項(xiàng)目列表,現(xiàn)在它是空白的;在中間部分會顯示APICloud的更新日志(APICloud平臺自上線以來一直堅(jiān)持每周更新一個版本)等平臺動向信息;右側(cè)是個人信息以及一些工具按鈕,如圖1-10所示。
?
? 圖1-10
點(diǎn)擊左上角的“創(chuàng)建應(yīng)用”,在彈出的窗口中選中“Native App”(默認(rèn)選項(xiàng)),在“名稱”輸入框中填入“HelloAPICloud”并在“說明”輸入框中填入任意說明信息,之后點(diǎn)擊創(chuàng)建。此時一個新的項(xiàng)目便被創(chuàng)建好了并顯示了剛剛創(chuàng)建項(xiàng)目的管理頁面,后續(xù)會對這個頁面的相關(guān)功能進(jìn)行循序漸進(jìn)的學(xué)習(xí)。
在項(xiàng)目創(chuàng)建完成后還需要將這個項(xiàng)目檢出到本地進(jìn)行開發(fā),APICloud支持通過git或svn進(jìn)行代碼管理(關(guān)于代碼版本管理的資料請查閱相關(guān)文檔),即便讀者不了解代碼版本管理的相關(guān)知識也不妨礙本節(jié)的學(xué)習(xí)。
打開APICloud Studio 2,如果開發(fā)者是首次運(yùn)行此開發(fā)工具則需要進(jìn)行登錄。請用之前創(chuàng)建的賬號進(jìn)行登錄,否則無法找到相應(yīng)的項(xiàng)目。登錄成功后會進(jìn)入歡迎頁面。
此時開發(fā)工具已經(jīng)獲得了賬號權(quán)限,可以對項(xiàng)目進(jìn)行操作了。點(diǎn)擊菜單欄的“代碼管理”→“代碼檢出”→“APICloud云端應(yīng)用”,在出現(xiàn)的檢索框中輸入之前創(chuàng)建的項(xiàng)目名稱“HelloAPICloud”,回車確認(rèn)(也可以從下面的模糊搜索結(jié)果中選擇相應(yīng)的項(xiàng)目,如圖1-11所示)。
?
? 圖1-11
在彈出的對話框中選擇這個項(xiàng)目在開發(fā)設(shè)備上的保存位置(例如在桌面上新建一個叫作“HelloAPICloud”的文件夾,然后選擇這個文件夾)并點(diǎn)擊“檢出”。
在新彈出的輸入框中保持默認(rèn),直接按回車即可,如圖1-12所示。
?
? 圖1-12
開發(fā)工具會自動從APICloud云端將賬號中的“HelloAPICloud”項(xiàng)目檢出到本地計(jì)算機(jī)上,稍等便可以看到默認(rèn)打開的代碼編輯頁面。
2.在APICloud Studio 2上創(chuàng)建新項(xiàng)目
打開APICloud Studio 2并登錄之前創(chuàng)建的賬號。點(diǎn)擊菜單欄中的“文件”→“新建”→ “APICloud移動應(yīng)用”,分別輸入應(yīng)用名稱和應(yīng)用說明,應(yīng)用框架選擇“空白應(yīng)用”,之后點(diǎn)擊完成。在彈出的對話框中選擇新項(xiàng)目的創(chuàng)建位置,點(diǎn)擊“創(chuàng)建”。
稍等便可以完成創(chuàng)建。此時在網(wǎng)站的控制臺中可以看到剛剛創(chuàng)建的項(xiàng)目。
本文摘自《30天App開發(fā)從0到1:APICloud移動開發(fā)實(shí)戰(zhàn)》
《30天App開發(fā)從0到1:APICloud移動開發(fā)實(shí)戰(zhàn)》
鄒達(dá), 李德興 著
本書介紹如何通過APICloud平臺快速開發(fā)一款A(yù)PP,從介紹APICloud平臺開始,從零搭建APP框架,對數(shù)據(jù)通信能力、js移動端應(yīng)用、APICloud引擎架構(gòu)、第三方開放平臺服務(wù)應(yīng)用發(fā)布和管理及更新迭代均有詳細(xì)講述。
隨后詳細(xì)對UI框架的使用進(jìn)行分析,通過對熱門行業(yè)的移動應(yīng)用開發(fā)解決方案的介紹,讓讀者掌握真正的實(shí)戰(zhàn)技巧——如何開發(fā)一款優(yōu)質(zhì)的APP。