微信小程序路由傳參

路由傳參常用方式有以下幾種

  1. 通過url傳參

    // 產(chǎn)品列表頁面
     <navigator url="/pages/detail/detail?productId=12345" hover-class="navigator-hover">詳情</navigator>
    
    // 或者
    wx.navigateTo({
      url: '/pages/detail/detail?productId=12345'
    })
    
    // 產(chǎn)品詳情頁面
    Page({
      onLoad: function(option){
        let productId = option.productId;
        console.log(productId);
      }
    })
    

    上面的方式的參數(shù)不能是對象,如果需要傳對象,可以將對象轉(zhuǎn)成json字符串,然后拼接到url后面,在接收頁面再將json字符串轉(zhuǎn)成對象

    let info = {
     a:2,
     b:3
    }
    let infoStr = JSON.stringfy(info);
    wx.navigateTo({
      url: '/pages/detail/detail?infoStr='+infoStr
    })
    
    // 產(chǎn)品詳情頁面
    Page({
      onLoad: function(option){
        let infoStr = option.infoStr;
        let info = JSON.parse(infoStr);
      }
    })
    
  1. 通過事件傳參

    1. 官網(wǎng)例子
    // 產(chǎn)品列表頁
    wx.navigateTo({
      url: url: '/pages/detail/detail'
      events: {
        // 為指定事件添加一個(gè)監(jiān)聽器佛析,獲取被打開頁面?zhèn)魉偷疆?dāng)前頁面的數(shù)據(jù)
        acceptDataFromOpenedPage: function(data) {
          console.log(data)
        },
        someEvent: function(data) {
          console.log(data)
        }
        ...
      },
      success: function(res) {
        // 通過eventChannel向被打開頁面?zhèn)魉蛿?shù)據(jù)
        res.eventChannel.emit('acceptDataFromOpenerPage', { data: 'test' })
      }
    })
    
    // 產(chǎn)品詳情頁
    Page({
      onLoad: function(option){
        const eventChannel = this.getOpenerEventChannel()
        eventChannel.emit('acceptDataFromOpenedPage', {data: 'test'});
        eventChannel.emit('someEvent', {data: 'test'});
        // 監(jiān)聽acceptDataFromOpenerPage事件,獲取上一頁面通過eventChannel傳送到當(dāng)前頁面的數(shù)據(jù)
        eventChannel.on('acceptDataFromOpenerPage', function(data) {
          console.log(data)
        })
      }
    })
    
  1. 簡化例子
    以上例子,在跳轉(zhuǎn)的時(shí)候列表頁可以向詳情頁傳數(shù)據(jù),詳情頁也可以向列表頁傳數(shù)據(jù),平時(shí)我們經(jīng)常都只是傳數(shù)據(jù),很少需要回傳,以下是簡化的例子
// 列表頁
wx.navigateTo({
  url: "/pages/home/detail/detail",
  success: function(res) {
    // 通過eventChannel向被打開頁面?zhèn)魉蛿?shù)據(jù)
    let data = {productId: 'sadf2323',productName:'金龍魚花生油'};
    res.eventChannel.emit("info", data);
  }
});
// 詳情頁
onLoad: function(options) {
  const eventChannel = this.getOpenerEventChannel();
  // 監(jiān)聽info事件惊奇,獲取上一頁面通過eventChannel傳送到當(dāng)前頁面的數(shù)據(jù)
  eventChannel.on("info", function(data) {
     console.log(data);
  });
},

總結(jié): 路由傳參可以用這兩種方式

  1. 通過url拼接參數(shù)傳輸,需要傳對象,需要傳對象就先講對象轉(zhuǎn)成json字符串再傳
  2. 通過eventChannel(事件通道)進(jìn)行傳輸(可以傳對象)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末殉了,一起剝皮案震驚了整個(gè)濱河市开仰,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌薪铜,老刑警劉巖众弓,帶你破解...
    沈念sama閱讀 216,997評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異隔箍,居然都是意外死亡谓娃,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評論 3 392
  • 文/潘曉璐 我一進(jìn)店門蜒滩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來滨达,“玉大人,你說我怎么就攤上這事俯艰〖癖椋” “怎么了?”我有些...
    開封第一講書人閱讀 163,359評論 0 353
  • 文/不壞的土叔 我叫張陵竹握,是天一觀的道長画株。 經(jīng)常有香客問我,道長啦辐,這世上最難降的妖魔是什么谓传? 我笑而不...
    開封第一講書人閱讀 58,309評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮芹关,結(jié)果婚禮上续挟,老公的妹妹穿的比我還像新娘。我一直安慰自己充边,他們只是感情好庸推,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著浇冰,像睡著了一般贬媒。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上肘习,一...
    開封第一講書人閱讀 51,258評論 1 300
  • 那天际乘,我揣著相機(jī)與錄音,去河邊找鬼漂佩。 笑死脖含,一個(gè)胖子當(dāng)著我的面吹牛罪塔,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播养葵,決...
    沈念sama閱讀 40,122評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼征堪,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了关拒?” 一聲冷哼從身側(cè)響起佃蚜,我...
    開封第一講書人閱讀 38,970評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎着绊,沒想到半個(gè)月后谐算,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,403評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡归露,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評論 3 334
  • 正文 我和宋清朗相戀三年洲脂,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片剧包。...
    茶點(diǎn)故事閱讀 39,769評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡恐锦,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出玄捕,到底是詐尸還是另有隱情踩蔚,我是刑警寧澤,帶...
    沈念sama閱讀 35,464評論 5 344
  • 正文 年R本政府宣布枚粘,位于F島的核電站馅闽,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏馍迄。R本人自食惡果不足惜福也,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望攀圈。 院中可真熱鬧暴凑,春花似錦、人聲如沸赘来。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,705評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽犬辰。三九已至嗦篱,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間幌缝,已是汗流浹背灸促。 一陣腳步聲響...
    開封第一講書人閱讀 32,848評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人浴栽。 一個(gè)月前我還...
    沈念sama閱讀 47,831評論 2 370
  • 正文 我出身青樓荒叼,卻偏偏與公主長得像,于是被迫代替她去往敵國和親典鸡。 傳聞我的和親對象是個(gè)殘疾皇子被廓,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評論 2 354

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