wepy踩坑記

wepy是一個(gè)微信小程序框架谆奥,支持模塊化開發(fā),開發(fā)風(fēng)格類似Vue.js菇肃〉胤啵可搭配redux使用,能同時(shí)打包出web和小程序琐谤。

官方文檔https://tencent.github.io/wepy

目錄結(jié)構(gòu):

20180311002840454.png

pages: 存放主頁(yè)面
sotre: redux(如果你創(chuàng)建項(xiàng)目時(shí)使用了redux的話)
components: 存放組件
mixins: 混合組件
wepy.config.js: webpack配置文件
app.wpy: 小程序入口文件
project.config.json: 小程序項(xiàng)目配置文件
index.template.html: web頁(yè)面的入口文件

mixins:

mixins是放混合組件的地方蟆技,比如很多page中都要用到wx.showToast方法。那么我們可以在mixins文件夾里面創(chuàng)建一個(gè)toast.js

# toast.js 
# mixins是js文件不是wpy文件
import wepy from 'wepy'

export default class testMixin extends wepy.mixin {
  onLoad () {  // onLoad生命周期鉤子函數(shù)
    this.showToast()
  }
  noMore () {  // 普通方法直接定義到class的靜態(tài)方法
    wepy.showToast({  // wepy.showToast 等同于 wx.showToast
      title: '沒有更多了...',
      icon: 'none',
      duration: 1500
    })
  }
  showToast () {
    wepy.showToast({
      title: '拼命加載中...',
      icon: 'loading',
      duration: 3000
    })
  }
  hideToast () {
    wepy.hideToast()
  }
}

其中wepy繼承了wx對(duì)象的方法斗忌,建議在wepy框架開發(fā)中不要用到wx對(duì)象的方法质礼,雖然運(yùn)行時(shí)效果是一樣,但是打包時(shí)會(huì)cli報(bào)錯(cuò)(wepy中沒有wx對(duì)象)飞蹂。
mixins的方法定義好后几苍,就可以在組件中使用mixin了。

# index.wpy
<script>
  import wepy from 'wepy'
  import toast from 'mixins/toast' // 導(dǎo)入mixins組件

  export default class Index extends wepy.page {
    onLoad () {
      this.showToast() // 導(dǎo)入和注冊(cè)后陈哑,就可直接使用
      this.getMovies()
    }
    mixins = [  // 注冊(cè)混合組件妻坝,注意mixins是一個(gè)數(shù)組
      toast
    ]
    ......
  }
</script>

首先在引入和注冊(cè)后,然后就可以直接調(diào)用this.showToast()
注意在wepy中組件中使用的是class,而不是vue中使用的Object惊窖。

methods, events:

vue中刽宪,所有方法都定義在methods里面。而在wepy中界酒,普通方法是直接定義在class類方法里面圣拄。events只定義組件間交互的方法。methods只定義事件方法毁欣。

# index.wpy
getSliderImg (data) { // 普通方法
  this.sliderImg = data.slice(0, 10)
  this.$apply()
}
onPullDownRefresh () {  // 頂部下拉刷新
  this.showToast()
  this.sliderImg = null
  this.active = true
  this.$apply()
  this.getMovies()
}
events = {  // 與子組件的交互庇谆,都要寫到events里面
  'showMovieDetail': (id) => {
    wepy.navigateTo({
      url: `./movie-detail?locationId=${290}&movieId=${id}`
    })
  }
}
methods = {
  toggleType (flag) { // 點(diǎn)擊事件方法
    this.active = flag
    this.showToast()
    this.getMovies()
  }
}

關(guān)于computed:

wepy中也有computed,propsdata,watchvue中有的一些屬性(沒有filter, directive)凭疮。
props,data,watchvue基本無(wú)異饭耳。

wepycomputed計(jì)算屬性是無(wú)法傳參的(本人沒能找到傳參的方法,且官方文檔沒有提到)执解,在處理一些動(dòng)態(tài)數(shù)據(jù)的時(shí)候寞肖,只能通過(guò)其他方法來(lái)操作。
比如,服務(wù)端獲取到的的JSON對(duì)象內(nèi)有條時(shí)間戳數(shù)據(jù)需要轉(zhuǎn)換成字符串新蟆,我的做法是將時(shí)間戳另外傳值給子組件觅赊,然后在子組件中使用computed對(duì)props進(jìn)行記算。

事件傳值:

wepy中的事件可傳遞一些基本類型的參數(shù)琼稻,但是需使用雙括號(hào)吮螺。否則獲取到的參數(shù)是字符串類型。

 <view @tap="toggleType({{true}})">

引用類型的參數(shù)可以使用 微信原生的 data- 屬性綁定數(shù)據(jù)欣簇,然后在函數(shù)中用e.currentTarget.dataset 獲取.

# template
<view data-movie="{{movie}}" @tap="showMovie"></view>

# script
methods = {
  showMovie (e) {
    console.log(e.currentTarget.dataset.movie) // 這樣就可以獲取到data屬性綁定的對(duì)象
  }
}

組件傳值:

wepy組件傳值的設(shè)計(jì)思路類似vue 1.0 规脸。這點(diǎn)在官方文檔講得比較詳細(xì)。需要注意是如果你需要props傳遞的數(shù)據(jù)跟隨父組件數(shù)據(jù)變化熊咽,要使用sync修飾符莫鸭。如果是異步獲取的服務(wù)端數(shù)據(jù),必須要在父組件使用 this.$apply()方法來(lái)觸發(fā)子組件的刷新横殴。
wepy中傳遞數(shù)據(jù)不能直接像vue中可以傳遞對(duì)象的屬性被因,如

<child :data="data.someData"></child> // vue寫法

但是在wepy中這樣的寫法會(huì)拿不到數(shù)據(jù)

# father.wpy
<child :data.sync="data"></child> // 動(dòng)態(tài)綁定數(shù)據(jù)需要sync修飾符

# child.wpy
# template
<text>{{someData}}</text> // 這樣就能獲取到someData了
# script
props = {
  data: Object
}
computed = {
  someData () {
    return this.data && this.data.someData
  }
}

動(dòng)態(tài)綁定class:

vue中動(dòng)態(tài)綁定class

# vue
<div class="class-a" :class="{true ? 'class-b': 'class-c'}"></div>

wepy中,要使用微信原生的綁定語(yǔ)法

<view class="class-a {{true ? 'class-b' : 'class-c'}}">

其中 class-a 是不需要?jiǎng)討B(tài)綁定的class衫仑, 雙括號(hào)中才是需要綁定的class

循環(huán)渲染組件:

wepy的循環(huán)渲染組件梨与,必須使用 <repeat/>標(biāo)簽,或者微信官方的<block/>標(biāo)簽(這兩個(gè)標(biāo)簽不會(huì)渲染到視圖層)否則就不會(huì)渲染成功文狱。

# wepy 提供的repeat組件
<view class="movie" wx:if="{{movies}}">
  <repeat for="{{movies}}" key="index" index="index" item="item">
    <movie :movie.sync="item"></movie>
  </repeat>
</view>
# 微信提供的block組件
<block wx:for="{{imgArr}}" wx:key="index">
  <swiper-item class="item" data-movieId="{{item.id}}" @tap="showMovieDetail">
    <image class="img" src="{{item.img || item.image}}"></image>
  </swiper-item>
</block>

wx:if:

wepy中使用 wx:if粥鞋,只阻止視圖渲染,不會(huì)阻止組件初始化瞄崇。
如在子組件onLoad 生命周期或者計(jì)算屬性中使用了一些父級(jí)傳遞過(guò)來(lái)的動(dòng)態(tài)數(shù)據(jù)呻粹,就會(huì)報(bào)錯(cuò)。

如何在wepy中使用stylus
http://www.reibang.com/p/749897519ec2

基于wepy和時(shí)光網(wǎng)api(僅做學(xué)習(xí)交流使用)構(gòu)建的微信小程序time
https://github.com/biliGates/time

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末苏研,一起剝皮案震驚了整個(gè)濱河市等浊,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌摹蘑,老刑警劉巖筹燕,帶你破解...
    沈念sama閱讀 219,188評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異衅鹿,居然都是意外死亡截粗,警方通過(guò)查閱死者的電腦和手機(jī)顷窒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門迹卢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)滑臊,“玉大人腻窒,你說(shuō)我怎么就攤上這事蓖谢∪楣妫” “怎么了锤岸?”我有些...
    開封第一講書人閱讀 165,562評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)切黔。 經(jīng)常有香客問(wèn)我砸脊,道長(zhǎng),這世上最難降的妖魔是什么纬霞? 我笑而不...
    開封第一講書人閱讀 58,893評(píng)論 1 295
  • 正文 為了忘掉前任凌埂,我火速辦了婚禮,結(jié)果婚禮上诗芜,老公的妹妹穿的比我還像新娘瞳抓。我一直安慰自己,他們只是感情好伏恐,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評(píng)論 6 392
  • 文/花漫 我一把揭開白布孩哑。 她就那樣靜靜地躺著,像睡著了一般翠桦。 火紅的嫁衣襯著肌膚如雪横蜒。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,708評(píng)論 1 305
  • 那天销凑,我揣著相機(jī)與錄音丛晌,去河邊找鬼。 笑死斗幼,一個(gè)胖子當(dāng)著我的面吹牛澎蛛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蜕窿,決...
    沈念sama閱讀 40,430評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼谋逻,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了渠羞?” 一聲冷哼從身側(cè)響起斤贰,我...
    開封第一講書人閱讀 39,342評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎次询,沒想到半個(gè)月后荧恍,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,801評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡屯吊,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評(píng)論 3 337
  • 正文 我和宋清朗相戀三年送巡,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片盒卸。...
    茶點(diǎn)故事閱讀 40,115評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡骗爆,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蔽介,到底是詐尸還是另有隱情摘投,我是刑警寧澤煮寡,帶...
    沈念sama閱讀 35,804評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站犀呼,受9級(jí)特大地震影響幸撕,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜外臂,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評(píng)論 3 331
  • 文/蒙蒙 一坐儿、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧宋光,春花似錦貌矿、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至菇民,卻和暖如春尽楔,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背第练。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工阔馋, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人娇掏。 一個(gè)月前我還...
    沈念sama閱讀 48,365評(píng)論 3 373
  • 正文 我出身青樓呕寝,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親婴梧。 傳聞我的和親對(duì)象是個(gè)殘疾皇子下梢,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評(píng)論 2 355

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

  • 測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)試測(cè)...
    七魂之月閱讀 893評(píng)論 1 16
  • 2018年的第10周即將結(jié)束了,這也將意味著2018年過(guò)完了將近1/5塞蹭。每當(dāng)進(jìn)行總結(jié)時(shí)孽江,就會(huì)感慨時(shí)間飛逝… 在過(guò)去...
    娃娃_83d2閱讀 179評(píng)論 0 0
  • 有朋友推薦《TED演講的力量》,終于利用這次去新疆的飛機(jī)上看完了這本書番电。 首先岗屏,正如李笑來(lái)在本書推薦序所表達(dá)的,這...
    你好閱讀王春霞閱讀 203評(píng)論 0 0
  • TCP重傳的原理 在TCP重傳的理論中漱办,重傳計(jì)時(shí)器是用于決定是否有必要進(jìn)行數(shù)據(jù)包重傳的一個(gè)主要機(jī)制这刷。重傳計(jì)時(shí)器維護(hù)...
    kevinhuangk閱讀 6,370評(píng)論 0 6
  • 【1】 城市邊緣,有些殘缺娩井。繁華的都市與這條街形成了鮮明的對(duì)比暇屋。 “龍哥,我很需要這場(chǎng)比賽洞辣,請(qǐng)你幫我安排一下”咐刨,一...
    冰釋主人閱讀 427評(píng)論 5 2