微信小程序页面之间传参的几种方式

这篇具有很好参考价值的文章主要介绍了微信小程序页面之间传参的几种方式。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

前言

第一种:url传值

url传值使用详细说明

api跳转

组件跳转

第二种:将值缓存在本地,再从本地取值

第三种:全局传值(应用实例传值)

第四种:组件传值

第五种:使用通信通道(通信通道是wx.navitageTo()独有的)

第六中:使用页面栈(只对当前页面栈中存在的页面生效)

总结


前言

  •  由于经常需要进行页面间传参且各种传参的业务场景也不相同,根据官方文档和日常工作进行了总结,共有六种传参方式。

概览

方式 优点 缺点
globalData 双向传参、全应用可用 不及时
storage 双向传参、全应用可用 不及时
路由 简单方便、及时 正向传参
通信通道 双向传参、及时 仅 wx.navagateTo() 接口调用才可用
页面栈 可操作数据和函数、及时 反向传参、仅 wx.navagateTo() 和<navigator open-type="navigateTo" url="/bbb?id=1"></navigator〉才可用

第一种:url传值

  • A页面部分js代码

 Page({
   toDetailPage: function (e) {
     var name = "斗帝蓝电霸王龙Pro";
     wx.navigateTo({
       url: '/pages/detail/detail?name =' + name,
     }
 })
  • B页面部分js代码

 Page({
   /**
     * onLoad生命周期函数--监听页面加载
    */
   onLoad: function (option) {
     console.log(option); // 斗帝蓝电霸王龙Pro
    /**
     * 这种普通函数中this的指向是动态的,为了保证函数内部可以访问到组件实例
     * 这里将this赋值给that
     * 如果你想直接使用this,可以使用箭头函数,箭头函数没有自己的this
     * 他会继承外层作用域的this
     * 在箭头函数中this的指向是定义的上下文,而不是执行时的上下文(`不清楚的可以看001例子说明`)
    */
     let that = this
     that.setData({
       name:option
     })
   },
 })
 // 001
 // 举个例子来说明:
 const obj = {
   name: '斗帝蓝电霸王龙Pro',
   sayHello: function() {
     console.log(`Hello, ${this.name}!`);
   },
   sayHelloArrow: () => {
     console.log(`Hello, ${this.name}!`);
   }
 };
 ​
 obj.sayHello(); // 输出:Hello, 斗帝蓝电霸王龙Pro!
 obj.sayHelloArrow(); // 输出:Hello, undefined!
 ​
 // 下面我来分析一下这段代码
    /**
     * sayHelloArrow是一个箭头函数。当我们调用obj.sayHello()时,
     * this指向的是调用该方法的对象obj,所以输出的结果是Hello, 斗帝蓝电霸王龙Pro!。
     * 而当我们调用obj.sayHelloArrow()时,由于箭头函数的this是在定义时确定的,
     * 而定义sayHelloArrow时的上下文是全局上下文,
     * 所以this.name实际上是指向全局对象(在浏览器中是window对象)的name属性,而全局对象
     * 没有name属性,所以输出的结果是Hello, undefined!。`
    */

url传值使用详细说明

  • 说明:url上直接携带参数长度是有限的且不支持特殊符号,可用编码、解码的方式解决, 在传参之前进行编码encodeURIComponent(), 接收的时候进行解码decodeURIComponent()。

api跳转

  • A页面部分js代码

 //跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面
 wx.switchTab({
     url:'/pages/detail/detail?id=5213828',
 })
 //关闭所有页面,打开到应用内的某个页面
 wx.reLaunch({
   url: '/pages/detail/detail?id=5213828',
 })
 //关闭当前页面,跳转到应用内的某个页面。但是不允许跳转到 tabbar 页面
 wx.redirectTo({
   url: '/pages/detail/detail?id=5213828',
 })
 //保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面。
 wx.navigateTo({
   url: '/pages/detail/detail?id='+ encodeURIComponent(this.data.id),
 })
 //以上四种路由方式在传参和接参上没有任何区别
  • B页面部分js代码

 Page({
   //地址传参带过来的参数只能在该方法的options参数中获取
   onLoad:function(options){
     console.log(decodeURIComponent(options.id)) // '5213828' ,无论传的变量是数字、布尔还是对象接收的时候都是字符串
   }
 })

组件跳转

  • A页面部分wxml

 <view>
   <navigator open-type="switchTab" url="/pages/detail/detail?id=5213828">
   跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面
   </navigator>
   <navigator open-type="reLaunch" url="/pages/detail/detail?id=5213828">
   关闭所有页面,打开到应用内的某个页面
   </navigator>
   <navigator open-type="redirectTo" url="/pages/detail/detail?id=5213828">
   关闭当前页面,跳转到应用内的某个页面。但是不允许跳转到 tabbar 页面
   </navigator>
   <navigator open-type="navigateTo" url="/pages/detail/detail?id=5213828">
   保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面
   </navigator>
 </view>
 //以上四种路由方式在传参和接参上没有任何区别
  • B页面部分js代码

 Page({
   //地址传参带过来的参数只能在该方法的options参数中获取
   onLoad:function(options){
     console.log(options.id) //'5213828' ,无论传的变量是数字、布尔还是对象接收的时候都是字符串
   }
 })

第二种:将值缓存在本地,再从本地取值

  • A页面部分js代码

 Page({
   toDetailPage: function (e) {
     var name = "斗帝蓝电霸王龙Pro";
     wx.setStorageSync("name", name);
     wx.navigateTo({
       url: '/pages/detail/detail'
     })
   }
 })
  • B页面部分js代码

 Page({
     /**
     * onLoad生命周期函数--监听页面加载
     */
   onLoad: function (option) {
     var name = wx.getStorageSync("name");
     console.log(name); // 斗帝蓝电霸王龙Pro
   }
 })

第三种:全局传值(应用实例传值)

  • app.js页面代码

 App({
   globalData: {
     name: '斗帝蓝电霸王龙'
   },
   // onLaunch 小程序启动时执行1次,常用于获取场景值或者启动时的一些参数(如自定义分享)
   onLaunch() {
   // 读取 token
     this.getToken()
   },
   getToken() {
     // 读取本地的token
     // this 指向应用实例本身
     this.token = wx.getStorageSync('token')
     this.refreshToken = wx.getStorageSync('refreshToken')
   },
   setToken(key, token) {
     // 存储到应例实例当中
     this[key] = token
     // 存储到本地存储当中
     wx.setStorageSync(key, token)
   }
 })
  • 其他页面js代码

 // 获取应用实例
 const app = getApp();
 Page({
   onLoad: function (option) {
     console.log(app.globalData.name); // 斗帝蓝电霸王龙
     // 重新存储新的 token
     app.setToken('token', '斗帝蓝电霸王龙Pro')
     app.setToken('refreshToken', '斗帝蓝电霸王龙Pro')
   },
   getToken() {
     console.log(app.token);  // 斗帝蓝电霸王龙Pro
     console.log(app.refreshToken); // 斗帝蓝电霸王龙Pro
   }
 })

第四种:组件传值

  • 父传子

    • 父组件

       // 父组件的wxml
       <classDetail  detail="{{name}}"></classDetail>
       // 父组件的js
       data:{
           name:"父组件---斗帝蓝电霸王龙Pro"
        }
       ​
       // 父组件的json(要把子组件注册进去)
       "usingComponents": {
           "classDetail": "./components/classDetail/index"
         }
    • 子组件

       // 子组件的js
         properties:{
           detail: String
         }
       ​
       // 子组件的wxml
       <view>{{detail}}<view>  // 父组件---斗帝蓝电霸王龙Pro子传父  
  • 子传父

    • 子组件

       // 子组件.wxml
       <button bindtap="changeSelect">添加</button>
       ​
       // 子组件的js
       changeSelect(){
         // 在子组件当中通过this.triggerEvent("自定义事件名",要传递的数据)
         this.triggerEvent("updataSelect", '子组件---斗帝蓝电霸王龙Pro')
       }
    • 父组件

       // 父组件的wxml
       // 在父组件的子标签中声明自定义事件 bind:自定义事件名="事件名"
       // 注意,这里的changeSelect是父组件js里的方法名称,updataSelect是子组件js里传递的方法名称
       <shudanbook index="{{ index }}" bind:updataSelect="changeSelect" ></shudanbook>
       ​
       // 父组件的js
         changeSelect(e){
         //获得传递过来的值
           console.log(e.detail) // 子组件---斗帝蓝电霸王龙Pro
         }

第五种:使用通信通道(通信通道是wx.navitageTo()独有的)

  • A页面部分js代码

 wx.navigateTo({
   url: "/pages/detail/detail?name='斗帝蓝电霸王龙Pro'",
   events: {
     // 为指定事件添加一个监听器,获取被打开页面传送到当前页面的数据
     acceptDataFromOpenedPage: function(data) { //参数名字随便起,前后页面对应上即可
     //对发送回来的数据进行处理
       console.log(data)         // 斗帝蓝电霸王龙Plus
     },
     someEvent: function(data) { // 参数名字随便起,前后页面对应上即可
       console.log(data)        // 斗帝蓝电霸王龙Pro max
     }
   },
   success: function(res) {
     // 通过eventChannel向被打开页面传送数据
     res.eventChannel.emit('acceptDataFromOpenerPage', { data: '斗帝蓝电霸王龙Pro' })//参数名字随便起,前后页面对应上即可
   }
 })
  • B页面部分js代码

 Page({
   onLoad: function(option){
     //获取通信通道
     const eventChannel = this.getOpenerEventChannel()
     // 监听acceptDataFromOpenerPage事件,获取上一页面通过eventChannel传送到当前页面的数据
     eventChannel.on('acceptDataFromOpenerPage', function(data) {
       //对发送过来的数据进行处理
       console.log(data)   // 斗帝蓝电霸王龙Pro
     })
     //向上一页面发送数据
     eventChannel.emit('acceptDataFromOpenedPage', {data: '斗帝蓝电霸王龙Plus'});
     eventChannel.emit('someEvent', {data: '斗帝蓝电霸王龙Pro max'});
   }
 })

第六中:使用页面栈(只对当前页面栈中存在的页面生效)

  • A页面部分js代码

 Page({
   data:{
     name:'斗帝蓝电霸王龙Pro',
     age:22
   },
   eatFood:function(food){
     console.log('eating '+ food)    
   }
 })
  • B页面部分js代码文章来源地址https://www.toymoban.com/news/detail-850463.html

 Page({
   onLoad: function (options) {
     // 获取当前页面栈
     const pages = getCurrentPages();
     // 获取上一页面对象
     let prePage = pages[pages.length - 2];
     console.log(prePage.data.name) // 斗帝蓝电霸王龙Pro
     prePage.eatFood('斗帝蓝电霸王龙Pro') // eating 斗帝蓝电霸王龙Pro
   }
 })

总结

  1. globalData与storage原理相同都是将数据放在一个公共的地方全应用随意取用,但是他们的数据不推送也不关联,即globalData和storage中的数据更新了,但已经获取过值的页面其对应的值并 不会更新。
  2. 解决办法:将各页面获取值的事件放到onShow()中,每次页面进入前台的时候都会重新从globalData和storage中取值。
  3. 路由携带参数简单方便,但是地址长度有限不能携带大量参数和特殊符号。
  4. 解决办法:在传参之前进行编码encodeURIComponent(),接收的时候进行解码 decodeURIComponent()。如此大量参数可以携带但是只能单方面传递参数,即只能a向b传,反之则不行。
  5. 通信通道,页面可以互相传参,但是该通道仅存在于wx.navagateTo()的接口调用时才有效。
  6. 页面栈,这是一个极其强大功能,它本质上不是向页面传参而是直接修改页面参数和方法。通过页面栈我们可以拿到该页面的对象,然后就可以对该页面的各项数据和函数进行操作。但是这种方法只能在b页面去操作a页面,并不能在a页面操作b页面,因为此时页面栈中还没有b。并且该方法也仅限于通过wx.navagateTo()或 <navigator open-type="navigateTo" url="/pages/detail/detail?id=5213828">跳转</navigator> 这两种方式进入b页面才可使用,因为其他方式跳转到b页面时已经销毁了其他所有页面,页面栈中已经没有上一个页面了。
     

到了这里,关于微信小程序页面之间传参的几种方式的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • JS中跳转传参的几种方法

    在JavaScript中,页面跳转并传递参数主要有以下几种方法: 1. 使用URL的查询字符串 这是最常见的方法,你可以在URL后面添加查询字符串来传递参数。查询字符串以 ? 开始,参数之间用 分隔。 例如: 在接收页面,你可以使用 window.location.search 来获取查询字符串,然后解析它来

    2024年04月26日
    浏览(29)
  • 【Vue3】路由传参的几种方式

    路由导航有两种方式,分别是:声明式导航 和 编程式导航 参数分为query参数和params参数两种 1.传参 在路由路径后直接拼接 ?参数名:参数值 ,多组参数间使用 分隔。 如果参数值为变量,需要使用模版字符串。 2.接收与使用 1.传参 to不再传递字符,而是传一个对象,由于参数

    2024年02月21日
    浏览(39)
  • 子组件向父组件传参的几种方法

    在用vue框架写项目的时候,多多少少会遇到子组件向父组件传参的方法。作为一个新手,确实让人头疼,于是便有了这篇小白写的总结,话不多说,开始! 以下方法全部基于这两个父子组件结构实现: 父组件 子组件 思路:在父组件中定义一个函数,通过props传递给子组件,

    2024年02月05日
    浏览(31)
  • 微信小程序和H5之间相互跳转的几种情况

    直接通过web-view内嵌的方式,有且只有这一种方式。 H5内嵌在小程序的web-view中,想要打开小程序自身的页面,可通过 wx.miniProgram.navigateTo 方法,参考链接:web-view | 微信开放文档 (qq.com) H5在非小程序环境中,微信浏览器或者手机自带浏览器打开时,想要跳转到小程序,可通过

    2024年02月11日
    浏览(35)
  • 微信小程序跳转传参的方法

    目的: 带着第一个页面的id,传到第二个页面,实现同一个页面,点击不同商品显示对应的数据 首先在第一个页面的js文件中写好接口 随后在wxml中写上点击事件,注意这个 data-id=\\\"{{item.id}}\\\" 随后在写上点击事件 先console一个e 看需要拿到什么数据  console的结果是 currentTarget下

    2024年02月06日
    浏览(31)
  • 小程序页面路由传参的方法?

    在小程序中,可以使用页面路由传递参数。有以下几种方式可以实现: 通过 URL 参数传递:在跳转到目标页面时,可以在 URL 中添加参数。例如: 在目标页面的 onLoad 方法中可以通过 options 参数获取传递的参数: 通过全局变量传递:可以通过小程序的全局变量来传递参数。在

    2024年01月17日
    浏览(38)
  • 微信小程序 method传参 和 页面传参

    image src=\\\"/img/b1.jpg\\\" class=\\\'bannerImg\\\' mode=\\\"widthFix\\\" bindtap=\\\"gotoMessage\\\" data-flag=\\\"msg\\\"/image 使用data-参数Key = \\\'指定参数值\\\' gotoMessage(e){     let flagName =  e.target.dataset.flag     if(flagName === \\\'msg\\\'){       wx.switchTab({         url: \\\'/pages/message/message\\\',       })     }else if(fla

    2024年02月09日
    浏览(40)
  • 微信小程序如何实现页面传参?

    只要你的小程序超过一个页面那么可能会需要涉及到页面参数的传递,下面我总结了 4 种页面方法。 通过在url后面拼接参数,参数与路径之间使用 ? 分隔,参数键与参数值用 = 相连,不同参数用 分隔;如 ‘path?key=valuekey2=value2’。 案例:A页面带参数跳转到B页面 A页面跳转代

    2024年02月15日
    浏览(32)
  • 微信小程序如何实现页面传参和页面传递多个参数

    只要你的小程序超过一个页面那么可能会需要涉及到页面参数的传递,下面我总结了 4 种页面方法。 下面时多个参数页面传参的方式   通过在url后面拼接参数,参数与路径之间使用 ? 分隔,参数键与参数值用 = 相连,不同参数用 分隔;如 ‘path?key=valuekey2=value2’。 案例:

    2024年02月11日
    浏览(56)
  • 创建微信小程序的几种方式

    在官网上下载微信开发者工具,之后使用微信开发者工具新建项目即可。 微信这边提供了多个模板,可以直接下载模板快速搭建上线,也可以使用空白模板根据需求自行编写。 空白模板项目结构: 对于刚接触小程序的开发者来说存在一些问题: 标签与普通 HTML 不同,对于

    2024年02月11日
    浏览(28)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包