小程序新手入門之基礎(chǔ)知識(shí)

一凑兰、前置知識(shí)

1掌桩、注冊(cè)帳號(hào),獲取appid姑食。

2波岛、微信開(kāi)發(fā)者工具:調(diào)試小程序、公眾號(hào)

3音半、與普通網(wǎng)頁(yè)開(kāi)發(fā)的區(qū)別:

(1)運(yùn)行環(huán)境:網(wǎng)頁(yè)開(kāi)發(fā)渲染與腳本在同一個(gè)線程上盆色,而小程序分為渲染層和邏輯層灰蛙。邏輯層運(yùn)行在jscore中,并沒(méi)有DOM和BOM隔躲。jscore環(huán)境與node也不同摩梧,所以也無(wú)法使用一些npm包。

(2)兼容性:
ios宣旱,安卓仅父,小程序開(kāi)發(fā)者工具3種環(huán)境,邏輯層與渲染層各不相同浑吟。


運(yùn)行環(huán)境

(3)整個(gè)小程序所有分包大小不超過(guò) 8M笙纤;單個(gè)分包不可超過(guò)2M

(4)開(kāi)發(fā)流程:開(kāi)發(fā)版本 ---> 體驗(yàn)版本 ---> 審核中版本 ---> 線上版本 ---> 發(fā)布
ps:若用戶未主動(dòng)刪除小程序,發(fā)布后最差24小時(shí)下發(fā)新版本(解決辦法:可通過(guò)啟動(dòng)時(shí)檢查更新)

二组力、小程序結(jié)構(gòu)及配置

1省容、項(xiàng)目結(jié)構(gòu)

--images
--pages
  --index
      --index.js
      --index.json
      --index.wxml
      --index.wxss
  --logs
      --index.js
      --index.json
      --index.wxml
      --index.wxss
--app.js
--app.json
--app.wxss
--project.config.json

2、配置文件
(1)project.config.json
開(kāi)發(fā)者工具自動(dòng)生成的一個(gè)配置文件燎字,和開(kāi)發(fā)者工具中【詳情】的配置一樣腥椒,一般不做更改。官方文檔

(2)app.json:全局配置文件候衍。官方文檔
舉個(gè)栗子

{
  "pages": [
    "pages/index/index",
    "pages/logs/index"
  ],
  "window": {
     "backgroundTextStyle": "light",
    "navigationBarBackgroundColor": "#fff",
    "navigationBarTitleText": "XX小程序",
    "navigationBarTextStyle": "black"
  },
  "tabBar": {
    "color": "#a5a5a5",
    "selectedColor": "#f63232",
    "borderStyle": "black",
    "backgroundColor": "#fff",
    "list": [{
      "pagePath": "pages/index/index",
      "iconPath": "images/course.png",
      "selectedIconPath": "images/course_red.png",
      "text": "首頁(yè)"
    }, {
      "pagePath": "pages/logs/logs",
      "iconPath": "images/study.png",
      "selectedIconPath": "images/study_red.png",
      "text": "日志"
    }]
  },
  "networkTimeout": {
    "request": 10000,
    "downloadFile": 10000
  },
  "debug": true,
  "navigateToMiniProgramAppIdList": [
    "wxe5f52902cf4de896"
  ],
  "sitemapLocation": "sitemap.json"
}

(3)頁(yè)面配置:附上官方文檔
每個(gè)頁(yè)面都可以有.json文件笼蛛,頁(yè)面配置中只能設(shè)置 app.json 中 window 對(duì)應(yīng)的配置項(xiàng),以決定本頁(yè)面的窗口表現(xiàn)蛉鹿,所以無(wú)需寫 window 這個(gè)屬性滨砍。頁(yè)面的window屬性會(huì)覆蓋全局window屬性。

{
    "usingComponents": {
        "ErrorPage": "./components/ErrorPage/index",
        "PPTLive": "./components/PPTLive/index",
        "Classroom": "./components/Classroom/index",
        "Loading": "./components/Loading/index"
    },
    "disableScroll": true,
    "pageOrientation": "landscape",
    "navigationStyle": "custom"
}

三妖异、小程序開(kāi)發(fā)

1惋戏、宿主環(huán)境


宿主環(huán)境
  • 通信:渲染層和邏輯層分別是2個(gè)線程管理。小程序的每個(gè)界面都是一個(gè)webview線程他膳。渲染層和邏輯層通過(guò)微信客戶端做中轉(zhuǎn)响逢。
  • 數(shù)據(jù)驅(qū)動(dòng):通過(guò)native

2、程序

// 程序構(gòu)造函數(shù)矩乐。app實(shí)例是單例對(duì)象龄句, js中可以通過(guò)getApp() 獲取該對(duì)象
App({
  onLaunch: function(options) {}, // 小程序初始化完成時(shí)觸發(fā)回论,only once
  onShow: function(options) {}, // 小程序啟動(dòng)散罕,或從后臺(tái)進(jìn)入前臺(tái)顯示時(shí)觸發(fā)
  onHide: function() {}, // 前臺(tái)進(jìn)入后臺(tái)觸發(fā)
  onError: function(msg) {}, // 腳本錯(cuò)誤或api吊用失敗時(shí)觸發(fā),帶上錯(cuò)誤信息
  globalData: 'I am global data'  // 全局data
}) 
  • 因?yàn)樾〕绦蛴卸喾N渠道打開(kāi)傀蓉,所以onLaunch和onShow可以帶options參數(shù)欧漱,包含path,query葬燎,scene误甚,shareTicket等缚甩。
  • globalData:切換webview時(shí),還是公用一個(gè)jscore窑邦,因?yàn)锳pp是單例擅威,所以可以通過(guò)app實(shí)例獲取全局?jǐn)?shù)據(jù)。

3冈钦、頁(yè)面

  • step1:創(chuàng)建js郊丛、json、wxml瞧筛、wxss4個(gè)文件
  • step2:app.json中聲明頁(yè)面路徑
  • step3:js文件中使用個(gè)頁(yè)面構(gòu)造器Page()
Page({
  data: { text: "This is page data." },
  onLoad: function(options) { }, // 頁(yè)面首次加載厉熟,only once,早于onShow和onReady较幌,options是
  onShow: function() { }, // 頁(yè)面每次加載
  onReady: function() { }, // 頁(yè)面初次渲染完成
  onHide: function() { }, // 頁(yè)面隱藏
  onUnload: function() { },  // 頁(yè)面卸載
  onPullDownRefresh: function() { },
  onReachBottom: function() { },
  onShareAppMessage: function () { },
  onPageScroll: function() { }
})

還可以添加任意的函數(shù)或數(shù)據(jù)揍瑟,在Page實(shí)例的其他函數(shù)中用 this 可以訪問(wèn)

  • step4:wxml文件中寫頁(yè)面結(jié)構(gòu)
    1)標(biāo)簽略有不同:view、text乍炉、image绢片、button、block等等
    2)數(shù)據(jù)綁定: {{}}
    3)wx:if, wx:for

  • step5:wxss中寫樣式
    1)單位:rpx(responsive pixel)恩急;以iphone6換算杉畜,1px=2rpx

  • 進(jìn)階tips:wxs (官方文檔)
    1)WeiXin Script運(yùn)行環(huán)境與js隔離,ios中比js快2~20倍衷恭,android中差不多
    2)運(yùn)行在視圖層此叠,適用于頻繁交互場(chǎng)景:如滑動(dòng)吸頂?shù)?/p>

4、組件:小程序提供了很多組件随珠,scroll-view灭袁,swiper,picker窗看,live-player茸歧,web-view等等

  • 原生組件:層級(jí)第二高,其他組件的無(wú)法蓋過(guò)原生組件显沈。z-index無(wú)效软瞎。camera、canvas拉讯、input涤浇、live-player、live-pusher魔慷、map只锭、textarea、video院尔。
  • 層級(jí)第一高:cover-image蜻展、cover-view

5喉誊、自定義組件:

Component({
  behaviors: [], // 類似mixins
  properties: {  // 頁(yè)面?zhèn)髦?    myProperty: { // 屬性名
      type: String,
      value: ''
    },
    myProperty2: String // 簡(jiǎn)化的定義方式
  },

  data: {}, // 私有數(shù)據(jù),可用于模板渲染

  lifetimes: {
    // 生命周期函數(shù)纵顾,可以為函數(shù)伍茄,或一個(gè)在methods段中定義的方法名
    attached: function () { },  // 在組件實(shí)例進(jìn)入頁(yè)面節(jié)點(diǎn)樹(shù)時(shí)執(zhí)行
    moved: function () { },  // 在組件實(shí)例被移動(dòng)到節(jié)點(diǎn)樹(shù)另一個(gè)位置時(shí)執(zhí)行    
    detached: function () { },   // 在組件實(shí)例被從頁(yè)面節(jié)點(diǎn)樹(shù)移除時(shí)執(zhí)行
  },

  // 生命周期函數(shù),可以為函數(shù)施逾,或一個(gè)在methods段中定義的方法名
  attached: function () { }, // 此處attached的聲明會(huì)被lifetimes字段中的聲明覆蓋
  ready: function() { }, //在組件在視圖層布局完成后執(zhí)行   

  pageLifetimes: {
    // 組件所在頁(yè)面的生命周期函數(shù)
    show: function () { },
    hide: function () { },
    resize: function () { },
  },

  methods: {
    onMyButtonTap: function(){
      this.setData({
        // 更新屬性和數(shù)據(jù)的方法與更新頁(yè)面數(shù)據(jù)的方法類似
      })
    },
    // 內(nèi)部方法建議以下劃線開(kāi)頭
    _myPrivateMethod: function(){
      // 這里將 data.A[0].B 設(shè)為 'myPrivateData'
      this.setData({
        'A[0].B': 'myPrivateData'
      })
    }
  }
})

6幻林、api:宿主環(huán)境提供的一系列功能 附上官方文檔

  • 基礎(chǔ): 系統(tǒng)、調(diào)試等方面的api
  • 路由:頁(yè)面間的跳轉(zhuǎn)
    1)wx.switchTab
    2)wx.reLaunch
    3)wx.redirectTo
    4)wx.navigateTo
    4)wx.navigateBack
  • 界面:通用的toast音念、loading沪饺、導(dǎo)航欄、動(dòng)畫等
  • 網(wǎng)絡(luò):wx.request等
  • 設(shè)備能力:藍(lán)牙闷愤、掃碼整葡、屏幕

7、事件

  • 渲染層傳遞給邏輯層
  • 常用:點(diǎn)擊讥脐、觸摸遭居、長(zhǎng)按等
<!-- page.wxml -->
<view id="tapTest" data-hi="WeChat" bindtap="tapName"> Click me! </view>

// page.js
Page({
  tapName: function(event) {
    console.log(event)
  }
})

四、項(xiàng)目介紹(wepy框架)

  • 風(fēng)格類似vue旬渠,上手快俱萍,開(kāi)發(fā)簡(jiǎn)單方便
  • 支持第三方npm包
  • 優(yōu)化:?jiǎn)挝募olyfill(es6)告丢、樣式編譯器
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末枪蘑,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子岖免,更是在濱河造成了極大的恐慌岳颇,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件颅湘,死亡現(xiàn)場(chǎng)離奇詭異话侧,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)闯参,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門瞻鹏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人鹿寨,你說(shuō)我怎么就攤上這事新博。” “怎么了释移?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵叭披,是天一觀的道長(zhǎng)寥殖。 經(jīng)常有香客問(wèn)我玩讳,道長(zhǎng)涩蜘,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任熏纯,我火速辦了婚禮同诫,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘樟澜。我一直安慰自己误窖,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布秩贰。 她就那樣靜靜地躺著霹俺,像睡著了一般。 火紅的嫁衣襯著肌膚如雪毒费。 梳的紋絲不亂的頭發(fā)上丙唧,一...
    開(kāi)封第一講書(shū)人閱讀 51,679評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音觅玻,去河邊找鬼想际。 笑死,一個(gè)胖子當(dāng)著我的面吹牛溪厘,可吹牛的內(nèi)容都是我干的胡本。 我是一名探鬼主播,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼畸悬,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼侧甫!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起蹋宦,我...
    開(kāi)封第一講書(shū)人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤闺骚,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后妆档,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體僻爽,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年贾惦,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了胸梆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡须板,死狀恐怖碰镜,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情习瑰,我是刑警寧澤绪颖,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站甜奄,受9級(jí)特大地震影響柠横,放射性物質(zhì)發(fā)生泄漏窃款。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一牍氛、第九天 我趴在偏房一處隱蔽的房頂上張望晨继。 院中可真熱鬧,春花似錦搬俊、人聲如沸紊扬。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)餐屎。三九已至,卻和暖如春玩祟,著一層夾襖步出監(jiān)牢的瞬間啤挎,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工卵凑, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留庆聘,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓勺卢,卻偏偏與公主長(zhǎng)得像伙判,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子黑忱,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355