uniapp 分享例子做个记录

<template>
    <view class="content">
        <view class="invite-wrapper" v-if="inviteUrl">
            <uni-qrcode class="invite-qrcode" ref="qrcode" cid="invite-qr-canvas" :text="inviteUrl" :margin="10" makeOnLoad
             @makeComplete="qrcodeComplete" />
            <view class="share-btn">
                <button type="primary" @click="shareLink">分享链接</button>
                <button type="primary" @click="shareImage">分享图片</button>
            </view>
            <view class="share-btn">
                <button type="primary" @click="toInvitedUser">我邀请的用户</button>
            </view>
            <uni-popup id="popupShare" ref="popupShare" type="share">
                <uni-popup-share title="分享到" :shareType="shareType" @select="select"></uni-popup-share>
            </uni-popup>
        </view>
    </view>
</template>

<script>
    import {
        mapState
    } from 'vuex'
    export default {
        data() {
            return {
                inviteUrl: '',
                qrcodeImagePath: '',
                qrcodePath: '',
                shareType: ''
            }
        },
        onLoad() {
            uni.showLoading({
                title: '加载中...'
            })
            uniCloud.callFunction({
                name: 'user-center',
                data: {
                    action: 'getInviteCode'
                },
                success: (res) => {
                    console.log(res);
                    if (res.result.code === 0) {
                        // 这里请修改为真实的邀请页面url
                        this.inviteUrl = 'https://login.tpl.dcloud.net.cn/#/pages/invite-reg/invite-reg?invite_code=' + res.result.myInviteCode
                    } else {
                        uni.showModal({
                            content: '获取用户邀请码失败:' + res.result.msg,
                            showCancel: false
                        })
                    }
                },
                fail: (err) => {
                    uni.showModal({
                        content: '获取用户邀请码失败,请稍后再试',
                        showCancel: false
                    })
                },
                complete() {
                    uni.hideLoading()
                }
            })
        },
        methods: {
            copyInviteUrl() {
                uni.setClipboardData({
                    data: this.inviteUrl
                })
            },
            qrcodeComplete(path) {
                this.qrcodeImagePath = path
            },
            shareLink() {
                this.shareType = 'link'
                this.$refs.popupShare.open()
            },
            shareImage() {
                this.shareType = 'image'
                this.$refs.popupShare.open()
            },
            select({
                item
            }) {
                const shareTitle = '登录模板',
                    shareSummary = 'DCloud邀请您试用登录模板'
                let params = {}
                switch (`${this.shareType}_${item.name}`) {
                    case 'link_weixin':
                        params = {
                            type: 1,
                            summary: this.inviteUrl,
                            scene: 'WXSceneSession'
                        }
                        break;
                    case 'link_qq':
                        params = {
                            type: 1,
                            title: shareTitle,
                            summary: shareSummary,
                            href: this.inviteUrl
                        }
                        break;
                    case 'link_more':
                        uni.setClipboardData({
                            data: this.inviteUrl
                        })
                        return
                    case 'image_weixin':
                        params = {
                            type: 2,
                            imageUrl: this.qrcodeImagePath,
                            scene: 'WXSceneSession'
                        }
                        break;
                    case 'image_qq':
                        params = {
                            type: 2,
                            imageUrl: this.qrcodeImagePath
                        }
                        break;
                    case 'image_more':
                        uni.shareWithSystem({
                            type: 'image',
                            imageUrl: this.qrcodeImagePath
                        })
                        return
                    default:
                        break;
                }
                console.log(params);
                uni.share({
                    provider: item.name,
                    ...params,
                    success() {
                        uni.showModal({
                            content: '分享成功',
                            showCancel: false
                        })
                    },
                    fail(err) {
                        uni.showModal({
                            content: '分享失败:' + err.errMsg,
                            showCancel: false
                        })
                    }
                })

            },
            toInvitedUser() {
                uni.navigateTo({
                    url: '/pages/invited-user/invited-user'
                })
            }
        }
    }
</script>

<style>
    .invite-wrapper {
        display: flex;
        padding: 20px;
        flex-direction: column;
        align-items: center;
    }

    .invite-qrcode {
        border-radius: 10px;
        box-shadow: rgba(0, 0, 0, 0.1) 0px 0px 10px 1px;
        overflow: hidden;
    }

    .share-btn {
        display: flex;
        flex-direction: row;
        padding: 20px 0px 10px 0px;
    }

    .share-btn button {
        flex: 1;
        margin: 0px 10px;
        border-radius: 40px;
    }
</style>