微信小程式開發的一點心得

ma125120發表於2019-01-05

1. 樣式問題

主要說一下微信小程式和之前的web開發中表現不一致的元素。

1.1 button 按鈕

有時候,我們需要實現自定義轉發的功能,但是重新設定button元素的樣式,這個時候你可能會發現不管怎麼設定button的樣式,它的邊框都去不掉。後來才知道原來是after偽元素的原因(如果是瀏覽器的話,如果有偽元素在開發者工具能直接看到,小程式就不行,這點我覺得還是有點坑的)。

解決方案:

.btn::after{
  border:none;
}
複製程式碼

順便列一下微信小程式button的預設樣式:

button {
    position: relative;
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding-left: 14px;
    padding-right: 14px;
    box-sizing: border-box;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    line-height: 2.55555556;
    border-radius: 5px;
    -webkit-tap-highlight-color: transparent;
    overflow: hidden;
    color: #000000;
    background-color: #F8F8F8;
}
複製程式碼

預設行高,padding,margin這幾個屬性還是要注意一下的。

1.2 image 圖片

小程式的image元素有一個mode屬性來設定圖片裁剪、縮放的模式,而且image元件預設寬度300px、高度225px。 也就是說,如果不設定mode屬性,只設定width的值,圖片肯定是會變形的,因為該圖片的高度現在是225px而不是自適應的。

提供兩種解決方案:

  1. 設定mode屬性
// mode 有 13 種模式,其中 4 種是縮放模式,9 種是裁剪模式。
// 我常用的模式是:
// widthFix 寬度不變,高度自動變化,保持原圖寬高比不變
// 也就是說設定mode="widthFix"後只設定width屬性,圖片也可以自適應

// wxml
<image
    mode="widthFix"
    class="info--head"
    src="{{src}}"></image>
// wxss
.info--head {
    width: 750rpx;
}
複製程式碼
  1. 不設定mode屬性,設定width和height將圖片的寬高固定,也不至於變形的太厲害,我覺得主要適用於輪播圖還有列表頁的縮圖之類的。

1.3 fixed定位

設定position: fixed; 的元素不能存在於 scroll-view 元素內,最好是在最外層,否則在ios系統上就會出現各種問題的。

2. 生命週期

2.1 進入主頁面 -> 進入子頁面 -> 返回主頁面

生命週期依次為: 主頁面onLoad -> 主頁面onShow -> 主頁面onReady -> 子頁面onLoad -> 子頁面onShow -> 子頁面onReady -> 子頁面onUnload -> 主頁面onShow。

可以看到在這個過程中子頁面的onHide並不會觸發。

2.2 tab頁之間進行切換

上一個tab頁onHide -> 當前tab頁onShow。

可以看到在 1 和 2 的過程中,tab頁都不會觸發 onUnload 事件。

2.3 onHide觸發時機

頁面隱藏/切入後臺時觸發。 如 navigateTo底部 tab 切換到其他頁面小程式切入後臺等。

2.4 onUnload觸發時機

頁面解除安裝時觸發。如 redirectTonavigateBack 到其他頁面時。

2.5 chooseImage

這個可是個我遇到的一個大坑,當呼叫 wx.chooseImage 這個API的時候,居然會觸發 該頁面的onHideonShow 事件,可能是因為我對 切入後臺時觸發onHide理解的不夠深刻???之前做的那個專案和 即時通訊IM 有關,我說為什麼選擇圖片之後聊天記錄怎麼就亂了呢,當時真的坑了我不少時間,真的是一個蘿蔔一個坑。

2.6 遇到的問題

主要是想在退出頁面的時候清除定時器,但是由於對 onHide 和 onUnload 觸發時機理解的不夠深刻,還專門開了 debug 具體除錯了一下生命週期,這下算是大致上明白了。

還有一點,很重要,如果是在 webview 內有定時器,在退出小程式頁面的時候一定要將 webview 的 src 屬性設定為 空, 不然webview好像並不會銷燬?反正我的定時器還在,設定src為空即可解決。

3. npm支援

官方的介紹只有4步:

  1. 在小程式中執行命令安裝 npm 包:npm install
  2. 點選開發者工具中的選單欄:工具 --> 構建 npm;
  3. 勾選“使用 npm 模組”選項;
  4. 構建完成後即可使用 npm 包。

照做一遍之後,嗯,很好。

微信小程式開發的一點心得
what???我的操作有誤嗎?總共也才4步,難道這我都能出錯?後來查了一下,發現還少了很重要的一步: package.json檔案。對呀,平時做專案的時候這個檔案都是最不可或缺的,怎麼到了微信小程式就給忘了呢,看來還是讀書太少了。

解決辦法:

  1. 先使用 npm init在專案根目錄下新建package.json檔案。
  2. 之後跟著官方文件照做吧,我就不寫了。

4. 新增的API

我上次寫小程式都是一年以前了,所以我覺得新增的API可能大家都很熟悉了,不喜輕噴哈。

4.1 wx.getImageInfo 獲取圖片資訊

該API用來獲取圖片的width, height, path, orientation,type 等資訊,可以看到不僅能獲取圖片的寬度和高度,還能將 網路圖片的地址換成本地圖片的地址,當然了,網路圖片需先配置download域名才能生效。

4.2 FileSystemManager.readFile 讀取本地檔案內容

通過指定 encoding 就可以得到類似於 html5 FileReader 的效果,比如將檔案讀取為 base64。小程式支援的 encoding 還是比較多的,可以自己看看官方文件的。

4.3 FileSystemManager.getFileInfo 獲取該小程式下的 本地臨時檔案 或 本地快取檔案 資訊

這個API主要是用來獲取檔案的大小,也就是size屬性。如果還需要檔案摘要,可以使用下面的API。

4.4 wx.getFileInfo 獲取檔案資訊

這個API主要是用來獲取檔案的size和digest資訊,目前支援 md5 和 sha1 兩種。

4.5 wx.pageScrollTo 將頁面滾動到目標位置

在做即時通訊的時候,如果收到新訊息,在增加內容以後也要滾動頁面至底部;下拉重新整理也得回到頂部。這個時候該API就很有用了,要不然很無奈呀,我記得一年以前好像是沒有這個功能的。

4.6 總結

其實列舉的都是我在做 小程式 和 騰訊雲IM 即時通訊的時候需要使用的API,騰訊雲IM官方文件只有web端的,小程式的直接讓你參考web端的,因為API的差異,基本上所有功能都需要自己封裝,一般的還好,IM上傳圖片這個可就坑了,IM只能傳送base64編碼的檔案,要不是看到小程式支援了base64編碼,我都差點放棄了。

在不考慮壓縮圖片的情況,從選擇圖片到傳送IM圖片訊息,光是小程式這邊我就得呼叫4個API,小程式就不能簡化一下嗎?

5. 獲取使用者資訊getUserInfo

這簡直就是一個巨坑,做專案之前我去社群看了一下,發現這個API現在不能彈窗提醒了,必須使用者點選按鈕才能獲取,就是說沒有按鈕,連彈窗都彈不出來的。針對這個問題,我直接給後臺說了,那邊居然說是別人家的就不用點選按鈕就能獲取,到你這怎麼還得點選按鈕?我跟你說,讓使用者點選按鈕肯定是不現實的,那多影響使用者體驗,你自己想辦法去。

what???官方都說的那麼明確了,只有3種解決辦法,每一種都繞不開按鈕,我能怎麼辦?最後費了半天口舌,再加上我把別人家的小程式也都放到他們跟前,讓他們一個個看清有沒有按鈕,總算是搞定了。

6.總結

說實話,作為一個開發者,我還是更喜歡web這種開發的平臺,微信小程式真的是一步一個坑,如果可以,真的不想做微信小程式呀! 可惜沒有如果o(╥﹏╥)o。

相關文章