目錄
app 部分:
##page 部分:
不支援過濾器
不支援函數
列表渲染
" >事件處理
三、组件
详细的不支持列表:
小程序组件
示例代码:
1. 如何获取小程序在 page onLoad 时候传递的 options
2. 如何获取小程序在 app onLaunch/onShow 时候传递的 options
3. 如何捕获 app 的 onError
首頁 web前端 js教程 mpvue開發小程式步驟詳解

mpvue開發小程式步驟詳解

May 24, 2018 pm 03:05 PM
mpvue 小程式 詳解

這次帶給大家mpvue開發小程式步驟詳解,mpvue開發小程式的注意事項有哪些,下面就是實戰案例,一起來看一下。

一、實例生命週期

除了Vue本身的生命週期處,mpvue也相容了小程式的生命週期,這部分生命週期的鉤子來自微信小程式的Page,除特殊情況外,不建議使用小程式的生命週期鉤子。

app 部分:

  • onLaunch,初始化

  • onShow,當小程式啟動,或從後台進入前台顯示

  • onHide,當小程式從前台進入後台

##page 部分:

  • onLoad,監聽頁面載入

  • onShow,監聽頁面顯示

  • onReady,監聽頁面初次渲染完成

  • onHide,監聽頁面隱藏

  • onUnload,監聽頁面卸載

  • onPullDownRefresh,監聽用戶下拉動作

  • onReachBottom,頁面上拉觸底事件的處理函數

  • onShareAppMessage,使用者點擊右上角分享

  • #onPageScroll,當頁面捲動

  • onTabItemTap, 目前是tab 頁時,點選tab 時觸發(mpvue 0.0.16 支援)

#用法範例:

new Vue({
  data: {
    a: 1
  },
  created () {
    // `this` 指向 vm 实例
    console.log('a is: ' + this.a)
  },
  onShow () {
    // `this` 指向 vm 实例
    console.log('a is: ' + this.a, '小程序触发的 onshow')
  }
})
// => "a is: 1"
登入後複製

注意點:

  1. #不要在選項屬性或回呼上使用箭頭函數,例如created: () => console.log(this.a) 或vm.$watch('a', newValue => this.myMethod())。因為箭頭函數是和父級上下文綁定在一起的,this不會是如你做預期的 Vue 實例,而 this.a 或 this.myMethod 也會是未定義的。

  2. 微信小程式的頁面的query 參數是透過onLoad 取得的,mpvue 對此進行了最佳化,直接透過

    this.$root.$mp.query取得對應的參數數據,其呼叫需要在onLoad 生命週期觸發之後使用,例如onShow 等

二、模板語法

不支援純-HTML

小程式裡所有的BOM/DOM 都不能用,也就是說v-html 指令不能用。

不支援部分複雜的JavaScript 渲染表達式

我們會把template 中的{{}} 雙花括號的部分,直接編碼到wxml 檔案中,由於微信小程式的能力限制(

資料綁定),所以無法支援複雜的JavaScript 表達式。

目前可以使用的有 - * % ?: ! == === > < [] .,剩下的還有待完善。

不支援過濾器

渲染部分會轉換成 wxml ,wxml 不支援過濾器,所以這部分功能不支援。

不支援函數

不支援在 template 內使用 methods 中的函數。

列表渲染

全支援官方文件:列表渲染

#只是需要注意一點,

嵌套列表渲染,必須指定不同的索引!

<!-- 在这种嵌套循环的时候, index 和 itemIndex 这种索引是必须指定,且别名不能相同,正确的写法如下 -->
<template>
    <ul v-for="(card, index) in list">
        <li v-for="(item, itemIndex) in card">
            {{item.value}}
        </li>
    </ul>
</template><h3 id="strong-事件處理-a-href-http-www-php-cn-code-html-target-blank-器-a-strong"><strong>事件處理<a href="http://www.php.cn/code/5688.html" target="_blank">器</a></strong></h3>#在 input 和 textarea 中 change 事件會被轉為 blur 事件。 <p style="text-align: left;"></p>
<h4 style="text-align: left;">踩坑注意:<strong></strong>
</h4>
<ul class=" list-paddingleft-2">
<li>清單中沒有的原生事件也可以使用例如bindregionchange 事件直接在dom 上將bind改為@<p style="text-align: left;">  @regionchange,同時這個事件也非常特殊,它的event type 有begin 和end<br>  兩個,導致我們無法在handleProxy 中區分到底是什麼事件,所以你在監聽此類事件的時候同時監聽事件名和事件類型既<br></p>
<pre class="brush:php;toolbar:false">   <map @regionchange="functionName" @end="functionName" @begin="functionName"><map>
登入後複製
  • 小程序能力所致,bind 和 catch 事件同时绑定时候,只会触发 bind ,catch 不会被触发,要避免踩坑。

  • 事件修饰符

    - .stop 的使用会阻止冒泡,但是同时绑定了一个非冒泡事件,会导致该元素上的 catchEventName 失效!
    登入後複製
    • .prevent 可以直接干掉,因为小程序里没有什么默认事件,比如submit并不会跳转页面

    • .capture 支持 1.0.9

    • .self 没有可以判断的标识

    • .once 也不能做,因为小程序没有 removeEventListener, 虽然可以直接在 handleProxy 中处理,但非常的不优雅,违背了原意,暂不考虑

  • 其他 键值修饰符 等在小程序中压根没键盘,所以。。。

  • 三、组件

    有且只能使用单文件组件(.vue 组件)的形式进行支持。其他的诸如:动态组件,自定义 render,和

    熱AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅動的應用程序,用於創建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用於從照片中去除衣服的線上人工智慧工具。

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Clothoff.io

    Clothoff.io

    AI脫衣器

    Video Face Swap

    Video Face Swap

    使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

    熱工具

    記事本++7.3.1

    記事本++7.3.1

    好用且免費的程式碼編輯器

    SublimeText3漢化版

    SublimeText3漢化版

    中文版,非常好用

    禪工作室 13.0.1

    禪工作室 13.0.1

    強大的PHP整合開發環境

    Dreamweaver CS6

    Dreamweaver CS6

    視覺化網頁開發工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神級程式碼編輯軟體(SublimeText3)

    Win11管理員權限取得詳解 Win11管理員權限取得詳解 Mar 08, 2024 pm 03:06 PM

    Windows作業系統是全球最受歡迎的作業系統之一,其新版本Win11備受矚目。在Win11系統中,管理員權限的取得是一個重要的操作,管理員權限可以讓使用者對系統進行更多的操作和設定。本文將詳細介紹在Win11系統中如何取得管理員權限,以及如何有效地管理權限。在Win11系統中,管理員權限分為本機管理員和網域管理員兩種。本機管理員是指具有對本機電腦的完全管理權限

    C++中的眾數函數詳解 C++中的眾數函數詳解 Nov 18, 2023 pm 03:08 PM

    C++中的眾數函數詳解在統計學中,眾數指的是一組資料中出現次數最多的數值。在C++語言中,我們可以透過寫一個眾數函數來找出任意一組資料中的眾數。眾數函數的實作可以採用多種不同的方法,以下將詳細介紹其中兩種常用的方法。第一種方法是使用哈希表來統計每個數字出現的次數。首先,我們需要定義一個哈希表,將每個數字作為鍵,出現次數作為值。然後,對於給定的資料集,我們遍

    Oracle SQL中的除法運算詳解 Oracle SQL中的除法運算詳解 Mar 10, 2024 am 09:51 AM

    OracleSQL中的除法運算詳解在OracleSQL中,除法運算是一種常見且重要的數學運算運算,用來計算兩個數相除的結果。除法在資料庫查詢中經常用到,因此了解OracleSQL中的除法運算及其用法是資料庫開發人員必備的技能之一。本文將詳細討論OracleSQL中除法運算的相關知識,並提供具體的程式碼範例供讀者參考。一、OracleSQL中的除法運算

    C++中的取餘函式詳解 C++中的取餘函式詳解 Nov 18, 2023 pm 02:41 PM

    C++中的取餘函數詳解在C++中,取餘運算子(%)用於計算兩個數相除的餘數。它是一種二元運算符,其運算元可以是任何整數型別(包括char、short、int、long等),也可以是浮點數型別(如float、double)。取餘運算子傳回的結果與被除數的符號相同。例如,對於整數的取餘運算,我們可以使用以下程式碼來實作:inta=10;intb=3;

    實作微信小程式中的卡片翻轉特效 實作微信小程式中的卡片翻轉特效 Nov 21, 2023 am 10:55 AM

    實作微信小程式中的卡片翻轉特效在微信小程式中,實現卡片翻轉特效是一種常見的動畫效果,可以提升使用者體驗和介面互動的吸引力。以下將具體介紹如何在微信小程式中實現卡片翻轉的特效,並提供相關程式碼範例。首先,需要在小程式的頁面佈局檔案中定義兩個卡片元素,一個用於顯示正面內容,一個用於顯示背面內容,具體範例程式碼如下:&lt;!--index.wxml--&gt;&l

    PHP模運算子的作用及用法詳解 PHP模運算子的作用及用法詳解 Mar 19, 2024 pm 04:33 PM

    PHP中的模運算子(%)是用來取得兩個數值相除的餘數的。在本文中,我們將詳細討論模運算子的作用及用法,並提供具體的程式碼範例來幫助讀者更好地理解。 1.模運算子的作用在數學中,當我們將一個整數除以另一個整數時,就會得到一個商和一個餘數。例如,當我們將10除以3時,商數為3,餘數為1。模運算子就是用來取得這個餘數的。 2.模運算子的用法在PHP中,使用%符號來表示模

    linux系統呼叫system()函數詳解 linux系統呼叫system()函數詳解 Feb 22, 2024 pm 08:21 PM

    Linux系統呼叫system()函數詳解系統呼叫是Linux作業系統中非常重要的一部分,它提供了一種與系統核心互動的方式。其中,system()函數是常用的系統呼叫函數之一。本文將詳細介紹system()函數的使用方法,並提供對應的程式碼範例。系統呼叫的基本概念系統呼叫是使用者程式與作業系統核心互動的一種方式。使用者程式透過呼叫系統呼叫函數來請求作業系統

    Linux的curl指令詳解 Linux的curl指令詳解 Feb 21, 2024 pm 10:33 PM

    Linux的curl命令詳解摘要:curl是一種強大的命令列工具,用於與伺服器進行資料通訊。本文將介紹curl指令的基本用法,並提供實際的程式碼範例,幫助讀者更好地理解和應用該指令。一、curl是什麼? curl是命令列工具,用於發送和接收各種網路請求。它支援多種協議,如HTTP、FTP、TELNET等,並提供了豐富的功能,如檔案上傳、檔案下載、資料傳輸、代

    See all articles