微信小程序--跨界面传值

前言

微信小程序现在越来越火爆,几乎在我们生活中的各个角落都能看到小程序的二维码,那么你知道如何在微信小程序中实现跨界面传值嘛

url传值

url可以实现传值,因为它可以携带很多参数在里面。我们可以在url后面加一个?号,后面可以传一些参数进去,多个参数中间用&连接:http://xiaocai.com/skip?para1=‘money’&para2='love’

然后我们再解析**?**号后面的字符串就能拿到传过去的值。

完整案例

本案例演示page1向page2传值,代码cv可用

page1.wxml

<button type="primary" bindtap="skip">点击跳转</button>

page1.js

skip:function(){
    //传数字
    let number=0
    //传字符串
    let str="字符串"
    //传json对象
    let json={
        name:'小王',
        age:18
    }
    //传json数组
    let jsonArray=[{
            name:'小赵',
            age:20
        },{
            name:'小李',
            age:18
     }]
     
    /**
     * url传值只能传字符串或数字,不能直接传json对象
     * 所以要把json,jsonArray转化为字符串传值
     * 当然到另一个界面要把字符串还原成json,jsonArray对象
     */
    let jsonstr=JSON.stringify(json)
    let jsonArraystr=JSON.stringify(jsonArray)
    
    //skipurl换成你要跳转的url
    //ex: ../page2/page2
	wx.navigateTo({
          url: 'skipurl?number='+number+'&str='+str+'&json='+jsonstr+'&jsonArray='+jsonArraystr,
    })
},

page2.js

onLoad: function (options) {
        //接收number
        let number = options.number
        //接收str
        let str = options.str
        //接收json字符串,并将json字符串还原json
        let json=JSON.parse(options.json)
        //接收jsonArray字符串,并将jsonArray字符串还原jsonArray
        let jsonArray=JSON.parse(options.jsonArray)
        //打印接收到的数据
        console.warn("传输数据成功!!")
        console.log(number)
        console.log(str)
        console.log(json)
        console.log(jsonArray)
},

注意:
onLoad函数中可以获取传过去的参数(小程序自动解析url获取?后面各个参数值)
onLoad是生命周期函数,在page中不能出现两次否则只执行第二次出现的onLoad函数(覆盖)
所以上面的代码你要在小程序中onLoad函数里面改,也就是你要复制的是上面代码块中onLoad里面的内容,将它复制到原本小程序固有的onLoad函数里

成功效果

小程序缓存传值

小程序缓存你只要不去清除它,它就一直存到缓存中。所以自然也就能够实现跨界面传值了

写入缓存:

let json={
        name:'小王',
        age:18
}

//把json写入缓存,设置主键test
wx.setStorage({
        data: json,
        key: 'test',
})

读取缓存:

 wx.getStorage({
         key: 'test',
 }).then(res=>{
     console.log('获取缓存成功')
     console.log(res.data)
 }).catch(res=>{
     console.log("404,没有找到缓存")
 })

在一个界面中写入缓存,在另一个界面读取缓存进而实现跨界面传值

app.js传值

利用全局的app.js进行传值,它之所以能传值,是因为所有的js文件都能通过调用const app=getApp()方法来获取到app.js中的值。

app.js

app.js是小程序目录里的文件,不需要你自己去建
下面这段代码演示的是 设置并初始化全局变量

//app.js
App({
  onLaunch: function () {
    
  }
  //设置并初始化全局变量,this指代整个App包含所有page
  //this.globalData指的是App中的变量
    this.globalData = {
         name:'cqg',
         sdept:'web前端'
    }
  }
})

page1.js

演示读取并修改全局变量,app.js里的值

const app=getApp()
console.log("读取全局变量name",app.globalData.name)
console.log("读取全局变量sdept",app.globalData.sdept)
//修改name
app.globalData.name='cqg001'
//修改sdept
app.globalData.sdept='github'

page2.js

演示读取修改后的全局变量

const app=getApp()
console.log("读取修改后的全局变量name",app.globalData.name)
console.log("读取修改后的全局变量sdept",app.globalData.sdept)

总结:我们今天学习了微信小程序跨界面传值方法

如果这篇博文能够帮到您,请点赞+收藏+关注

  • 1
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值