小程序页面传值

简介: 本文介绍了微信小程序中父子页面的传值方法。父页面向子页面传值可通过绑定事件跳转,使用`data-`属性传递参数,然后在子页面的`onLoad`中接收。子页面向父页面传值则通过用户选择内容后调用父页面的方法,利用`getCurrentPages()`获取父页面实例,进而修改父页面的数据。

一、父页面向子页面传值

一、通过绑定事件跳转

1.vxml在你需要跳转的按钮或者图片中绑定bindtap的内容,data-是需要跳转的参数的,其中的id为你想要跳转的参数。{}中的为跳转后携带的值。

<view class="body_left">
    <image src="/image/pause.png" bindtap="goPaly" data-id="{
   
   {item.id}}"></image>
  </view>

==data-表示此次绑定事件要传的参数==
2.js页面中通过固定语句语法e.currentTarget.dataset为语法,其中在后面加入你的跳转参数。然后通过微信的wx.navigateTo进行跳转。其中在URL的路径中问好前面的为你需要跳转的路径,后面的为跳转的参数以及携带的值

goPaly(e){
   
   
  console.log('点击了',ids)
  wx.navigateTo({
   
   
    url: '/pages/palyMusic/palyMusic?id='+id+'&ids='+ids,
  })
},

==1.wx.navigateTo 保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面。==
==2.wx.switchTab跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面==
3.跳转页面的接受数据js,通过页面的监听函数onLoad函数进行页面的接受。options来接受数据

onLoad: function (options) {
   
   
    // 接受id
    var id=options.i
    this.setData({
   
   
      id:id
    })
  },

二、通过标签直接跳转

<navigator url="/pages/index/index"></navigator>

二、子页面向父页面传值

==通过父页面跳转到子页面,由用户选择内容后将选择的内容携带传到父页面。==
xml在你需要跳转的按钮或者图片中绑定bindtap的内容,data-是需要跳转的参数的,其中的id为你想要跳转的参数。{}中的为跳转后携带的值。
1.父页面

<view bindtap="chooseTopic">{
   
   {
   
   topic}}</view>

js

 data: {
   
   
   topic:"请选择话题"
  },
 chooseTopic(){
   
   
   wx.navigateTo({
   
   
     url: '/pages/topic/topic',
   })
 },

在这里插入图片描述

2.子页面
html

<view class="content" wx:for="{
   
   {topicList}}">
 <view class="item" bindtap="chooseTopic" data-name="{
   
   {item}}">
  <view>{
   
   {
   
   item.title}}</view>
  <view>{
   
   {
   
   item.count}}</view>
 </view>
</view>

js

  */
  data: {
   
   
   topicList:[
     {
   
   title:'过年了',count:'100'},
     {
   
   title:'回家了',count:'200'}
   ]
  },
  chooseTopic(e){
   
   
   var topiceInfo= e.currentTarget.dataset.name
   //获取到当前的页面
   var pages=getCurrentPages()
   //获取到父页面
   var prepages=pages[pages.length-2];
  //1.直接修改父页面的值
   prepages.setData({
   
   
     topic:topiceInfo.title
    })
       // 2.通过方法体传值
    prepages.setTopice(topiceInfo)
   console.log(topiceInfo)
   wx.navigateBack({
   
   })
 },

在这里插入图片描述

以上是本人的学习经验,希望可以帮助更多的人。

目录
相关文章
|
1月前
|
移动开发 小程序
如何让uni-app开发的H5页面顶部原生标题和小程序的顶部标题不一致?
如何让uni-app开发的H5页面顶部原生标题和小程序的顶部标题不一致?
|
1月前
|
缓存 小程序 UED
微信小程序如何在切换页面后原页面状态不变
微信小程序如何在切换页面后原页面状态不变
94 0
|
1月前
|
小程序 UED 开发者
小程序如何监听页面的滚动事件
小程序如何监听页面的滚动事件
52 0
|
1月前
|
JSON 小程序 JavaScript
【微信小程序】-- 自定义组件 - 组件所在页面的生命周期 & 插槽(三十七)
【微信小程序】-- 自定义组件 - 组件所在页面的生命周期 & 插槽(三十七)
|
1月前
|
小程序
【微信小程序】-- 页面导航 -- 编程式导航(二十三)
【微信小程序】-- 页面导航 -- 编程式导航(二十三)
|
22天前
|
小程序 JavaScript 数据库
小程序登录页面
该文介绍了使用小程序云开发实现登录和注册的步骤,包括界面设计和后端逻辑。界面使用了`wxss`和`wxml`编写,样式精致,包含手机号和密码输入、登录按钮、注册和忘记密码选项。在`js`中,重点处理了用户输入的账号和密码,通过云数据库查询验证用户是否存在,使用标志位`flag`判断,若账号或密码错误,显示相应提示。文章总结了利用for循环比对数据库账号的难点,并表达了作者的学习心得。
24 1
|
1月前
|
小程序
小程序和页面生命周期详解
小程序和页面生命周期详解
21 0
|
1月前
|
存储 缓存 小程序
微信小程序页面传值的几种方式
微信小程序页面传值的几种方式
|
1月前
|
小程序
小程序页面路由传参的方法?
小程序页面路由传参的方法?
27 0
|
1月前
|
缓存 小程序 开发者
微信小程序如何刷新当前页面
微信小程序如何刷新当前页面
103 0

热门文章

最新文章