麻豆黑色丝袜jk制服福利网站-麻豆精品传媒视频观看-麻豆精品传媒一二三区在线视频-麻豆精选传媒4区2021-在线视频99-在线视频a

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 小程序頁面傳參之事件傳參

小程序頁面傳參之事件傳參

來源:千鋒教育
發布人:wjy
時間: 2022-06-06 13:40:00 1654494000

當我們在開發小程序的時候,經常會遇到此類要求:點擊一個內容跳轉到一個新的頁面,并且新頁面的內容是由點擊的內容決定的。

小程序頁面傳參之事件傳參

 比如用戶在美團上瀏覽商品,通常情況下我們去查看詳情頁面,會發現它的結構都是相同或者類似的,但是內容是由用戶點擊的內容決定的。

比如點擊黃燜雞,進到詳情頁就會發現封面是黃燜雞,這和我們點擊的內容是一一對應的。

這種效果在小程序開發過程中十分常見。今天我們拿一個音樂類的小程序舉例子,看看頁面之間的數據是如何進行關聯的。

**需求:**

用戶點擊圖1中的播放按鈕時,跳轉到圖2,然后播放圖1中對應列表的歌曲。

小程序頁面傳參之事件傳參1

(圖1) (圖2)

在本例中,如果點擊圖1“孤勇者”后面的播放按鈕,跳轉到圖2,則播放“孤勇者”,且圖2中的歌曲名字顯示為“孤勇者”這首音樂。

如果點擊圖1“太陽”后面的播放按鈕,跳轉到圖2,則播放“太陽”,且圖2中的歌曲名字顯示為“太陽”這首音樂。

**思考幾個問題:**

1.如何點擊后跳轉到新頁面?

2.如何將圖1中的信息傳遞到圖2中?

3.圖2中的歌曲名字如何做到和圖1中一致?

**簡單分析下過程:**

**1.如何跳轉?**

給圖1中的播放按鈕綁定一個事件,在事件中使用wx.navigateTo({ url: url }) 跳轉到新頁面。

**2.頁面中參數如何傳遞給js?**

微信小程序提供自定義屬性,即data-*,若組件上觸發的事件,會發送給事件處理函數。

也就是說data-*自定義的內容可以在事件執行的時候獲取出來。然后用一個變量接收,并與需要跳轉的地址進行拼接,實現明文傳參。

**3.當前Js中的參數如何傳給另一個頁面的js?**

當前js使用wx.navigateTo({ url: url?Key=value})明文傳參,下個頁面在頁面一加載時就執行onload:function(options){}函數,此函數中的參數options就是用來接收所有信息的,它里面包含了傳遞過來的參數。

**4.得到前一個頁面傳遞的參數后,如何調用后端接口并渲染到前端頁面上?**

構建一個歌曲詳情渲染的方法,方法中包含請求后端數據的過程,請求成功后重置data中的變量。然后在onload中調用此方法。前端頁面通過{{}}綁定data中定義的數據內容。

代碼過程:

**1、歌曲詳情頁面:**

給播放按鈕綁定一個點擊事件,綁定的事件中需要具備兩個作用。一是接收事件傳遞的參數,二是攜帶接收到的參數跳轉到新的頁面。

```text
Songlist.Wxml

<!-- 歌曲列表 -->
<view class="musicContainer" wx:for="{{songlist}}" wx:key="songlist">
    <!-- 左邊封面 -->
    <view class="left">
        <image src="{{item.songImg}}"></image>
    </view>
    <!-- 中間歌曲信息 -->
    <view class="center">
        <view class="songName">{{item.songName}}</view>
        <view class="singerName">{{item.singerName}} · {{item.songName}}</view>
    </view>
    <!-- 右邊播放按鈕 -->
<view class="right">
 <!-- bindtap綁定點擊事件,點擊事件的名稱為gotoPlay -->
 <!-- data-id自定義一個屬性,可以跟隨事件傳遞 -->
        <image bindtap="gotoPlay" data-id="{{item.id}}" src="/images/playIcon.png"></image>
    </view>
</view>
```

**songlist.js中的初始數據**

```text
data: {
        songlist:[
         
            {
                "id":"1901371647",
                "songImg":"                "songName":"孤勇者",
                "singerName":"陳奕迅"
            }
]
}
```

**songlist.js中定義gotoPlay方法, 用于攜帶參數跳轉**

```text
// 監聽播放圖標的點擊
gotoPlay:function(even){
  // even代表執行這個點擊事件時傳遞過來的所有信息
        var mid=even.currentTarget.dataset.id;
        // 用mid來接收data-id傳遞過來的id值;
        wx.navigateTo({
// 跳轉到新頁面。同時攜帶參數id=mid
            url: '/pages/play/play?id='+mid
        })    
    }
```

**2.播放頁面:**

**Play.wxml**

```text
<!-- 歌曲名字 -->
    <view class="songName">{{musicName}}</view>
```

**Play.js**

```text
Page({
/**
     * 頁面的初始數據
     */
    data: {
        id:"",
        musicName:"",
        musicPic:"",
    },

    /**
     * 生命周期函數--監聽頁面加載
     */
    onLoad: function (options) {
        var mid =options.id
        var index1=options.index
        // this指的是當前對象,這里指的是play
        // console.log(options)
        this.setData({
            id:mid
        })
        // 歌曲詳情的渲染
        this.musicShow()
    },

    // 歌曲詳情渲染的方法
    musicShow(){
        var id=this.data.id
        // console.log(id)
        var that=this
        // 用that存儲當前對象,網絡請求時,this指的是當前網絡對象,不是當前的play對象
        // 通過歌曲id來進行接口的數據拼接
        var url="https://music.163.com/api/song/detail/?ids=["+id+"]"
        // 網絡請求
        wx.request({
          url: url,
          success (res) {
            //   console.log(res)
            var name=res.data.songs[0].name
            // console.log(res.data.songs[0].id)
            var pic=res.data.songs[0].album.picUrl
            that.setData({
                "musicPic":pic,
                "musicName":name
            })
          }
        })
    }

})
```

**最終結果:**

點擊圖1中播放按鈕,跳轉到圖2播放頁,且圖2中的歌曲名稱就是圖1中的歌曲名字。

小程序頁面傳參之事件傳參2

**- End -**

更多關于web培訓的問題,歡迎咨詢千鋒教育在線名師。千鋒教育擁有多年IT培訓服務經驗,采用全程面授高品質、高體驗培養模式,擁有國內一體化教學管理及學員服務,助力更多學員實現高薪夢想。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
主站蜘蛛池模板: 麻豆免费高清完整版视频| 在线观看亚洲免费| 精品久久久久香蕉网| 一本免费视频| 日本黄色网战| 无翼乌口工| 小莹的性荡生活37章| 一级片在线免费看| а√最新版在线天堂| 99久久无色码中文字幕| 两根硕大一起挤进小h| 星空无限传媒在线观看| 国产一级黄色录像| 免费视频日韩| 中文字幕亚洲一区二区三区| 国产精品毛片大码女人| 精品久久久久久亚洲精品| 国产精品久久久久无码av| 在线观看网站禁入口不用下载| 国产成人综合欧美精品久久| 丰乳娇妻镇| 国产剧情乱偷| 扒开老师的蕾丝内裤漫画| 五月深爱网| 欧美特黄色片| 玩山村女娃的小屁股| 2019天天干夜夜操| 亚洲第一成年免费网站| 韩国无遮挡羞羞漫画| 麻豆精品不卡国产免费看 | 免费网站看v片在线香蕉| 全彩里番acg海贼王同人本子| 精品日韩欧美一区二区三区| 中文字幕免费在线| 一边摸一边叫床一边爽| 人体大胆做受免费视频| 最近高清国语中文在线观看免费| 乱人伦中文字幕电影| 一级毛片大全免费播放下载| 香蕉97超级碰碰碰免费公| www.99精品|