Taro 初探踩坑

安裝

Taro 項目基于 node,請確保已具備較新的 node 環(huán)境(>=8.0.0)鼻疮,推薦使用 node 版本管理工具 nvm 來管理 node

 $ npm install -g @tarojs/cli

使用

初始化一個名為myApp的項目:

 $ taro init myApp

之后按照官網(wǎng)說明輸入您的配置膜蠢,忘了截圖了丽涩,各位自由發(fā)揮吧

編譯

執(zhí)行命令

 $ npm run dev:weapp

這個時候坑出現(xiàn)了,報錯提示沒有XXX模塊(沒有截圖蝌戒,名稱忘了)

于是召烂,我執(zhí)行命令

 $ npm install XXX

報錯:

image

原因:

需要安裝Visual Studio

解決方式:

通過官網(wǎng)下載安裝VS(我下載的是2017)

注意的是在安裝VS2017的過程中需要選上Common Tools for Visual C++的選項碱工,因為默認是不選擇的

最后把npm的vs版本設置成2017(不執(zhí)行這個貌似也可以)

打開命令行,輸入

 npm config set msvs_version 2017

安裝設置完VS后奏夫,執(zhí)行 npm install XXX怕篷,之后執(zhí)行npm run dev:weapp

到這基本成功了,

之后自行下載并打開微信開發(fā)者工具酗昼,然后選擇項目根目錄進行預覽廊谓。

(大坑注意:一定要下載穩(wěn)定版本,我當初下載了最新的版本仔雷,弄了很久沒有出來Hello world!)

image

Taro項目結構分析

image

由于個人習慣蹂析,開發(fā)中我是用webstrom開發(fā),下面是一個簡單的demo

image

生命周期函數(shù)

生命周期方法 作用 說明
componentWillMount 程序被載入 對應微信小程序onLaunch
componentDidMount 程序被載入 對應微信小程序onLaunch碟婆,在componentWillMount之后執(zhí)行
componentDidShow 程序展示出來 對應微信小程序onShow
componentDidHide 程序被隱藏 對應微信小程序onHide

路由

在 Taro 中电抚,路由功能是默認自帶的,不需要開發(fā)者進行額外的路由配置竖共。

// 跳轉到目的頁面蝙叛,打開新頁面
Taro.navigateTo({
  url: '/pages/page/path/name'
})

// 跳轉到目的頁面,在當前頁面打開
Taro.redirectTo({
  url: '/pages/page/path/name'
})

傳參

// 傳入?yún)?shù) id=2&type=test
Taro.navigateTo({
  url: '/pages/page/path/name?id=2&type=test'
})

我們可以使用this.$router.params來獲取路由上的參數(shù)公给。

組件

Taro 以 微信小程序組件庫 為標準借帘,結合 jsx 語法規(guī)范,定制了一套自己的組件庫規(guī)范淌铐,具體可以自行去看文檔

 //listItem.tsx
import Taro, { Component } from '@tarojs/taro'
import { View, Text } from '@tarojs/components'
import './listItem.scss'
export default class ListItem extends Component {
  skipToDetail(){
    /* 必須得這樣寫=肺然。= */
    this.props.onClick()
  }
  render() {
    const { title, description } = this.props
    return (
      <View className='list-item' onClick={this.skipToDetail}>
        <View><Text>{title}</Text></View>
        <View><Text>{description}</Text></View>
      </View>
    )
  }
}

主頁

import Taro, {Component, Config} from '@tarojs/taro'
import {View, Text} from '@tarojs/components'
import ListItem from '../../components/ListItem'
import './index.scss'
import img0 from './img/11.jpg'
import img1 from './img/22.jpg'
import img2 from './img/33.jpg'

export default class Index extends Component {
  config: Config = {
    navigationBarTitleText: '首頁'
  }

  componentWillMount() {
  }

  componentDidMount() {
  }

  componentWillUnmount() {
  }

  componentDidShow() {
  }

  componentDidHide() {
  }

  skipToDetail({title, description}) {
    Taro.navigateTo({
      url: `/pages/detail/index?title=${title}&description=${description}`
    })
  }

  render() {
    const listSet = [
      {title: '標題一', description: '描述一'},
      {title: '標題二', description: '描述二'},
      {title: '標題三', description: '描述三'},
    ]
    return (
      <View className='index'>
        <Swiper indicatorDots autoplay>
          {[img0, img1, img2].map(img => (<SwiperItem key={img}><Image src={img}/></SwiperItem>))}
        </Swiper>
        {listSet.map(item => (
          <ListItem onClick={this.skipToDetail.bind(this, item)} description={item.description} title={item.title}
                    key={item.title}/>))}
      </View>
    )
  }
}

詳情

//detail/index.tsx
import Taro, {Component} from '@tarojs/taro'
import {View} from '@tarojs/components'
import './index.scss'

export default class Index extends Component {
  componentWillMount() {
  }

  config = {
    navigationBarTitleText: '詳情頁'
  }

  render() {
    const {title, description} = this.$router.params
    return (
      <View>
        詳情
      </View>
    )
  }
}

demo預覽,點擊標題可以跳轉到詳情

image
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末腿准,一起剝皮案震驚了整個濱河市际起,隨后出現(xiàn)的幾起案子拾碌,更是在濱河造成了極大的恐慌,老刑警劉巖街望,帶你破解...
    沈念sama閱讀 212,816評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件校翔,死亡現(xiàn)場離奇詭異,居然都是意外死亡灾前,警方通過查閱死者的電腦和手機防症,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來哎甲,“玉大人蔫敲,你說我怎么就攤上這事√棵担” “怎么了燕偶?”我有些...
    開封第一講書人閱讀 158,300評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長础嫡。 經(jīng)常有香客問我,道長酝惧,這世上最難降的妖魔是什么榴鼎? 我笑而不...
    開封第一講書人閱讀 56,780評論 1 285
  • 正文 為了忘掉前任,我火速辦了婚禮晚唇,結果婚禮上巫财,老公的妹妹穿的比我還像新娘。我一直安慰自己哩陕,他們只是感情好平项,可當我...
    茶點故事閱讀 65,890評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著悍及,像睡著了一般闽瓢。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上心赶,一...
    開封第一講書人閱讀 50,084評論 1 291
  • 那天扣讼,我揣著相機與錄音,去河邊找鬼缨叫。 笑死椭符,一個胖子當著我的面吹牛,可吹牛的內容都是我干的耻姥。 我是一名探鬼主播销钝,決...
    沈念sama閱讀 39,151評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼琐簇!你這毒婦竟也來了蒸健?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,912評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎纵装,沒想到半個月后征讲,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,355評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡橡娄,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,666評論 2 327
  • 正文 我和宋清朗相戀三年诗箍,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片挽唉。...
    茶點故事閱讀 38,809評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡滤祖,死狀恐怖,靈堂內的尸體忽然破棺而出瓶籽,到底是詐尸還是另有隱情匠童,我是刑警寧澤,帶...
    沈念sama閱讀 34,504評論 4 334
  • 正文 年R本政府宣布塑顺,位于F島的核電站汤求,受9級特大地震影響,放射性物質發(fā)生泄漏严拒。R本人自食惡果不足惜扬绪,卻給世界環(huán)境...
    茶點故事閱讀 40,150評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望裤唠。 院中可真熱鬧挤牛,春花似錦、人聲如沸种蘸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽航瞭。三九已至诫硕,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間沧奴,已是汗流浹背痘括。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留滔吠,地道東北人纲菌。 一個月前我還...
    沈念sama閱讀 46,628評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像疮绷,于是被迫代替她去往敵國和親翰舌。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,724評論 2 351

推薦閱讀更多精彩內容

  • 概要 64學時 3.5學分 章節(jié)安排 電子商務網(wǎng)站概況 HTML5+CSS3 JavaScript Node 電子...
    阿啊阿吖丁閱讀 9,146評論 0 3
  • 一:什么是閉包冬骚?閉包的用處椅贱? (1)閉包就是能夠讀取其他函數(shù)內部變量的函數(shù)懂算。在本質上,閉包就 是將函數(shù)內部和函數(shù)外...
    xuguibin閱讀 9,557評論 1 52
  • 我們非常榮幸地宣布 Visual Studio 2017 現(xiàn)已推出庇麦! 此次發(fā)布提供新的輕量模塊式安裝體驗计技,可根據(jù)自...
    三夢哥閱讀 7,709評論 0 6
  • Node.js第一天 1. 初識Node.js 1.1 Node.js是什么 Node.js? is a Java...
    再見天才閱讀 4,724評論 1 24
  • 談判跟吃飯差不多,每處利益所在即是一盤菜山橄,沒有人愿意餓著肚子離開餐桌垮媒。 在餐桌上,這個菜多吃了航棱,那么必...
    Lyuao閱讀 305評論 0 7