zoukankan      html  css  js  c++  java
  • 微信小程序之数据传递

    本文主要介绍,页面跳转间的数据传递。传递的数据类型主要有1,基本数据类型;2,对象;3,数组集合;

    先告诉你,本质上都是string类型传递。但是对于对象和数组集合的传递需要小小的处理一下传递时的数据和接收后的数据。

    1,传递基本数据类型

    index.js 发送页JS

    Page({
      data: {
        testStr: '字符串str'
      },
      onLoad: function () {
      },
      next: function(e){
        wx.navigateTo({
          url: '/pages/test/test?str='+this.data.testStr,
        })
      }
    })

    test.js 接受页JS

    Page({
      data:{
      },
      onLoad:function(options){
        console.log("接收到的参数是str="+options.str);
      }
    })
    打印的Log如下:
    接收到的参数是str=字符串str
     
    2,传递对象{}
    index.js 发送页JS
    Page({
      data: {
        testData:{name:'我是name', extra:'我是extra'}
      },
      onLoad: function () {
      },
      next: function(e){
        wx.navigateTo({
          url: '/pages/test/test?extra='+JSON.stringify(this.data.testData)
        })
      }
    })

    test.js 接受页JS

    Page({
      data:{
        testData:null
      },  
        onLoad:function(options){    
        console.log("接收到的参数是obj="+options.extra);//此处打印出来的仅仅是字符串 需要解析,解析如下
        this.dat.testData = JSON.parse(options.extra);//解析得到对象
      }
    })
    打印的Log如下:
    test.js [sm]:16 接收到的参数是obj={"name":"我是name","extra":"我是extra"}
     
    3,传递数组集合[ ]
    index.js 发送页JS
    Page({
      data: {
        list:['item-A','item-B']
      },
      onLoad: function () {
      },
      next: function(e){
        wx.navigateTo({
          url: '/pages/test/test?list='+JSON.stringify(this.data.list),
        })
      }
    })

    test.js 接受页JS

    Page({
      data:{
        list:[]
      },  
        onLoad:function(options){    
        console.log("接收到的参数是list="+options.list);//此处打印出来的是字符串,解析如下        
         this.data.list = JSON.parse(options.list);//解析得到集合
     }})
    打印的Log如下:
    test.js [sm]:17 接收到的参数是list=["item-A","item-B"]
     
     
    另外,还可以通过缓存(wx.setStorage(OBJECT),wx.setStorageSync(KEY,DATA))来传递数据,只是保存后需要清除,防止缓存过大的情况
    转载自:https://blog.csdn.net/wangsf789/article/details/53433676/

      

  • 相关阅读:
    基于HSI颜色模型实现去除照片的“红眼现象”
    《学习OpenCV》练习题第三章第六题
    《学习OpenCV》练习题第三章第八题a
    《学习OpenCV》练习题第三章第四题
    《学习OpenCV》练习题第三章第五题
    《学习OpenCV》练习题第三章第二题
    指针引发的一个传值和传址的问题
    数据结构之查找算法总结笔记
    位运算之左移右移运算之详解
    如何解决: emulator5554 disconnected! Cancelling 'com.example.android.snake.Snake activity launch'!的问题
  • 原文地址:https://www.cnblogs.com/PYiP/p/9767836.html
Copyright © 2011-2022 走看看