zoukankan      html  css  js  c++  java
  • 【uniapp 开发】UniPush

    App.vue

    export default {  
       onLaunch: function() {  
           // #ifdef APP-PLUS  
           const _self = this;  
           const _handlePush = function(message) {  
               // TODO  
           };  
           plus.push.addEventListener('click', _handlePush);  
           plus.push.addEventListener('receive', _handlePush);  
           // #endif  
       }  
    }  
    

    回调中的处理

    • 较为常见的场景是,收到 Push 消息后根据推送消息的信息,跳转到某个指定的页面。
    uni.navigateTo({  
    url: message.payload.pagePath  
    });  
    
    • 如果某个数据信息,需要在推送成功后同步到其它页面,就需要用到 vuex 了。

    vuex

    /store/index.js

    export default new Vuex.Store({  
       state: {  
           pushMessage: {}  
       },  
       mutations: {  
           updatePushMessage(state, message) {  
               /**  
                * 注意:这里为了方便预览查看效果,始终对 payload 做了序列化的处理。  
                * 实际开发期中,请自行调整代码并注意发送的 payload 消息格式。  
                */   
               let payload = message.payload;  
               if (typeof payload !== 'string') {  
                   message.payload = JSON.stringify(payload);  
               }  
               state.pushMessage = message || {};  
           }  
       }  
    }) 
    
    

    消息同步

    在 App.vue 中更新推送消息

    export default {  
       onLaunch() {  
           // #ifdef APP-PLUS  
           const _self = this;  
           const _handlePush = function(message) {  
               /**  
                * 通过 vuex 来同步页面的数据,仅做演示。  
                * 实际开发中,这里可能是跳转到某个页面等操作,请根据自身业务需求编写。  
                */  
               _self.updatePushMessage(message);  
           };  
           plus.push.addEventListener('click', function(message) {  
               plus.nativeUI.toast('push click');  
               _handlePush(message);  
           });  
           plus.push.addEventListener('receive', function(message) {  
               plus.nativeUI.toast('push receive');  
               _handlePush(message);  
           });  
           // #endif  
       },  
       methods: {  
           ...mapMutations(['updatePushMessage'])  
       }  
    }  
    

    /pages/index/index.vue 页面渲染推送消息结果

    <view>  
        <text class="title">推送消息 title:{{pushMessage.title}}</text>  
        <text class="title">推送消息 content:{{pushMessage.content}}</text>  
        <text class="title">推送消息 payload:{{pushMessage.payload}}</text>  
        <text class="title">推送消息 aps:{{pushMessage.aps}}</text>  
    </view>  
    

    测试发布

    推送功能,涉及到第三方的 SDK 模块,因此与登录、分享等功能类似,需要打包后生效。

    • 阅读 UniPush开通指南 开通服务
    • manifest.json->App SDK配置,勾选“DCloud UniPush”。
    • manifest.json->App模块权限配置,勾选 Push(消息推送)。
    • 提交打包,自定义基座或正式打包均可。

    参考文档

    UniPush使用指南
    UniPush开通指南
    Push模块

  • 相关阅读:
    数组中重复的数字-剑指Offer
    不用加减乘除做加法-剑指Offer
    扑克牌顺子-剑指Offer
    左旋转字符串-剑指Offer
    翻转单词顺序列-剑指Offer
    和为S的连续正数序列-剑指Offer
    和为S的两个数字-剑指Offer
    数组中只出现一次的数字-剑指Offer
    平衡二叉树-剑指Offer
    二叉树的深度-剑指Offer
  • 原文地址:https://www.cnblogs.com/neo-java/p/11305695.html
Copyright © 2011-2022 走看看