美文网首页简明uniapp教程uin-app
页面通讯 - 使用url传参或使用全局变量共享数据

页面通讯 - 使用url传参或使用全局变量共享数据

作者: 瑟闻风倾 | 来源:发表于2019-12-27 12:44 被阅读0次

    1. 页面传值

    说明:页面生命周期的onLoad()监听页面加载,其参数为上个页面传递的数据,参数类型为Object(用于页面传参)。如:

    • 页面 1 传递参数
    //页面跳转并传递参数
    uni.navigateTo({
        url: 'page2?name=liy&message=Hello'
    });
    

    url为将要跳转的页面路径 ,路径后可以带参数。参数与路径之间使用?分隔,参数键与参数值用=相连,不同参数用&分隔。如 'path?key1=value2&key2=value2',path为下一个页面的路径,下一个页面的onLoad函数可得到传递的参数。

    • 页面 2 接收参数
    onLoad: function (option) { //option为object类型,会序列化上个页面传递的参数
            console.log(option.name); //打印出上个页面传递的参数。
            console.log(option.message); //打印出上个页面传递的参数。
        }
    

    注意:url有长度限制,太长的字符串会传递失败,可使用窗体通信全局变量,或encodeURIComponent等多种方式解决。

    2. 页面传值示例

    2.1 传递简单参数

    • home.vue中传递参数
    <template>
        <view>
            <page-head :title="title"></page-head>
            <view class="uni-padding-wrap uni-common-mt">
                <view class="uni-btn-v">
                    <button @tap="navigateTo">跳转新页面,并传递数据</button>
                </view>
            </view>
        </view>
    </template>
    <script>
    export default {
        data() {
            return {
                title: '主页',
            }
        },
        methods: {
            navigateTo() {
                uni.navigateTo({
                    url: 'new-page1?data=Hello'
                })
            }
        }
    }
    </script>
    <style>
    
    </style>
    
    • new-page1.vue 中接收数据
    <template>
        <view>
            <view>
                {{data}}
            </view>
        </view>
    </template>
    <script>
        export default {
            data() {
                return {
                    data:""
                }
            },
            onLoad(e){
                if(e.data){
                    this.data = e.data;
                    console.log(e.data); //打印出上个页面传递的参数。
                }
            }
        }
    </script>
    <style>
        
    </style>
    

    2.2 传递数据集合

    (1) 方案一:使用url携带参数

    • home.vue中传递数据集合
    <template>
        <view>
            <page-head :title="title"></page-head>
            <view class="uni-padding-wrap uni-common-mt">
                <view class="uni-btn-v">
                    <button @tap="JumpToNewPage">跳转新页面,并传递数据集合</button>
                </view>
            </view>
        </view>
    </template>
    <script>
    export default {
        data() {
            return {
                title: '主页',
                processList:[
                    {
                        "process_id": "5",
                        "process_name": "卷下盘"
                    },
                    {
                        "process_id": "3",
                        "process_name": "接后片"
                    },
                    {
                        "process_id": "6",
                        "process_name": "接前片"
                    },
                    {
                        "process_id": "7",
                        "process_name": "水洗标"
                    },
                    {
                        "process_id": "8",
                        "process_name": "钉扣"
                    },
                    {
                        "process_id": "1",
                        "process_name": "贴口袋"
                    },
                    {
                        "process_id": "2",
                        "process_name": "做袖叉"
                    },
                    {
                        "process_id": "3",
                        "process_name": "做袖英"
                    },
                    {
                        "process_id": "4",
                        "process_name": "缝衣领"
                    }
                ]
            }
        },
        methods: {
            JumpToNewPage:function(){
                console.log("JumpToNewPage-processList1:" + JSON.stringify(this.processList));
                var processList = JSON.stringify(this.processList);
                uni.navigateTo({
                    url: 'new-page2?processList=' + processList
                })
            }
        }
    }
    </script>
    <style>
    
    </style>
    
    • new-page2.vue 中接收数据集合
    <template>
        <view>
            <view v-for="(item,index) in processList" :key="index">
                {{item.process_name}}
            </view>
        </view>
    </template>
    <script>
    export default {
        data() {
            return {
                processList:[]
            }
        },
        onLoad(options){
            if(options.processList){
                console.log("onLoad-processList2:" + options.processList);
                // this.processList = options.processList;
                // console.log("onLoad-processList3:" + this.processList);
                this.processList = JSON.parse(options.processList);
                console.log("onLoad-processList3:" + JSON.stringify(this.processList));
            }
        }
    }
    </script>
    <style>
    
    </style>
    

    (2) 方案二:使用全局变量共享数据

    • App.vue 中定义全局变量
    <script>
    export default {
        globalData:{
            processList:[]
        },
        onLaunch: function() {
            console.log('App Launch');
        },
        onShow: function() {
            console.log('App Show')
        },
        onHide: function() {
            console.log('App Hide')
        }
    }
    </script>
    
    <style>
    
    </style>
    
    
    • home.vue 中为全局变量赋值
    <template>
        <view>
            <page-head :title="title"></page-head>
            <view class="uni-padding-wrap uni-common-mt">
                <view class="uni-btn-v">
                    <button @tap="JumpToNewPage">跳转新页面,并传递数据集合</button>
                </view>
            </view>
        </view>
    </template>
    <script>
    export default {
        data() {
            return {
                title: '主页',
                processList:[
                    {
                        "process_id": "5",
                        "process_name": "卷下盘"
                    },
                    {
                        "process_id": "3",
                        "process_name": "接后片"
                    },
                    {
                        "process_id": "6",
                        "process_name": "接前片"
                    },
                    {
                        "process_id": "7",
                        "process_name": "水洗标"
                    },
                    {
                        "process_id": "8",
                        "process_name": "钉扣"
                    },
                    {
                        "process_id": "1",
                        "process_name": "贴口袋"
                    },
                    {
                        "process_id": "2",
                        "process_name": "做袖叉"
                    },
                    {
                        "process_id": "3",
                        "process_name": "做袖英"
                    },
                    {
                        "process_id": "4",
                        "process_name": "缝衣领"
                    }
                ]
            }
        },
        methods: {
            JumpToNewPage:function(){
                console.log("JumpToNewPage-processList1:" + JSON.stringify(this.processList));
                /* var processList = JSON.stringify(this.processList);
                uni.navigateTo({
                    url: 'new-page2/new-page2?processList=' + processList
                }); */
                getApp().globalData.processList = this.processList;//赋值
                uni.navigateTo({
                    url: 'new-page2/new-page2?'
                });
            },
        }
    }
    </script>
    <style>
    
    </style>
    
    • new-page2.vue 中获取全局变量
    <template>
        <view>
            <view v-for="(item,index) in processList" :key="index">
                {{item.process_name}}
            </view>
        </view>
    </template>
    <script>
    export default {
        data() {
            return {
                processList:[]
            }
        },
        onLoad(options){
            // if(options.processList){
            //  console.log("onLoad-processList2:" + options.processList);
            //  // this.processList = options.processList;
            //  // console.log("onLoad-processList3:" + this.processList);
            //  this.processList = JSON.parse(options.processList);
            //  console.log("onLoad-processList3:" + JSON.stringify(this.processList));
            // }
            this.processList = getApp().globalData.processList;//取值
            console.log("onLoad-processList2:" + JSON.stringify(this.processList));
        }
    }
    </script>
    <style>
    
    </style>
    

    js中操作globalData的方式如下:

    • 赋值:getApp().globalData.name= 'liy'
    • 取值:console.log(getApp().globalData.name) // 'liy'

    如果需要把globalData的数据绑定到页面上,可在页面的onshow声明周期里进行变量重赋值。

    相关文章

      网友评论

        本文标题:页面通讯 - 使用url传参或使用全局变量共享数据

        本文链接:https://www.haomeiwen.com/subject/ynjfoctx.html