关于小程序:uniapp小程序隐私协议弹窗组件

44次阅读

共计 3297 个字符,预计需要花费 9 分钟才能阅读完成。

为标准开发者的用户集体信息处理行为,保障用户的合法权益,自 2023 年 9 月 15 日起,对于波及解决用户个人信息的小程序开发者,微信要求,仅当开发者被动向平台同步用户已浏览并批准了小程序的隐衷爱护指引等信息处理规定后,方可调用微信提供的隐衷接口。

官网文档

用户隐衷爱护

成果展现

原插件地址

uniapp 的操作指引

1、批改文件 mainfest

新增参数 "__usePrivacyCheck__" : true, 如图

2、新建组件

新建目录文件为 components/privacy-popup/privacy-popup.vue

<template>
    <view v-if="showPrivacy" :class="privacyClass">
        <view :class="contentClass">
            <view class="title"> 用户隐衷爱护指引 </view>
            <view class="des">
                感谢您抉择应用咱们的小程序,咱们非常重视您的集体信息安全和隐衷爱护。应用咱们的产品前,请您仔细阅读“<text class="link" @tap="openPrivacyContract">{{privacyContractName}} </text>”,如您批准此隐衷爱护指引, 请点击批准按钮, 开始应用此小程序, 咱们将尽全力爱护您的个人信息及合法权益,感谢您的信赖!<br />
            </view>
            <view class="btns">
                <button class="item reject" @tap="exitMiniProgram"> 回绝 </button>
                <button id="agree-btn" class="item agree" open-type="agreePrivacyAuthorization"
                    @agreeprivacyauthorization="handleAgreePrivacyAuthorization"> 批准 </button>
            </view>
        </view>
    </view>
</template>

<script>
    export default {
        name: 'PrivacyPopup',
        data() {
            return {
                isRead: false,
                showPrivacy: false,
                privacyContractName: '',
                resolvePrivacyAuthorization: null,
            };
        },
        props: {
            position: {
                type: String,
                default: 'center'
            }
        },
        computed: {privacyClass() {return this.position === 'bottom' ? 'privacy privacy-bottom' : 'privacy';},
            contentClass() {return this.position === 'bottom' ? 'content content-bottom' : 'content';}
        },
        mounted() {if (wx.onNeedPrivacyAuthorization) {wx.onNeedPrivacyAuthorization((resolve) => {this.resolvePrivacyAuthorization = resolve;});
            }

            if (wx.getPrivacySetting) {
                wx.getPrivacySetting({success: (res) => {console.log(res, 'getPrivacySetting');
                        if (res.needAuthorization) {
                            this.privacyContractName = res.privacyContractName;
                            this.showPrivacy = true;
                        }
                    },
                });
            }
        },

        methods: {openPrivacyContract() {
                wx.openPrivacyContract({success: () => {this.isRead = true;},
                    fail: () => {
                        uni.showToast({
                            title: '遇到谬误',
                            icon: 'error',
                        });
                    },
                });
            },
            exitMiniProgram() {wx.exitMiniProgram();

            },
            handleAgreePrivacyAuthorization() {
                this.showPrivacy = false;
                if (typeof this.resolvePrivacyAuthorization === 'function') {
                    this.resolvePrivacyAuthorization({
                        buttonId: 'agree-btn',
                        event: 'agree',
                    });
                }
            },
        },
    };
</script>

<style scoped>
    .privacy {
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        background: rgba(0, 0, 0, .5);
        z-index: 9999999;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .privacy-bottom {align-items: flex-end;}

    .content {
        width: 632rpx;
        padding: 48rpx;
        box-sizing: border-box;
        background: #fff;
        border-radius: 16rpx;
    }

    .content-bottom {
        position: absolute;
        bottom: 0;
        width: 96%;
        padding: 36rpx;
        padding-bottom: constant(safe-area-inset-bottom);
        padding-bottom: env(safe-area-inset-bottom);
        border-radius: 16rpx 16rpx 0 0;
    }

    .content .title {
        text-align: center;
        color: #333;
        font-weight: bold;
        font-size: 32rpx;
    }

    .content .des {
        font-size: 26rpx;
        color: #666;
        margin-top: 40rpx;
        text-align: justify;
        line-height: 1.6;
    }

    .content .des .link {
        color: #07c160;
        text-decoration: underline;
    }

    .btns {
        margin-top: 48rpx;
        margin-bottom: 12rpx;
        display: flex;
    }

    .btns .item {
        width: 200rpx;
        height: 72rpx;
        overflow: visible;
        display: flex;
        align-items: center;

        justify-content: center;
        /* border-radius: 16rpx; */
        box-sizing: border-box;
        border: none !important;
    }

    .btns .reject {
        background: #f4f4f5;
        color: #666;
        font-size: 14px;
        font-weight: 300;
        margin-right: 16rpx;
    }

    .btns .agree {
        width: 320rpx;
        background: #07c160;
        color: #fff;
        font-size: 16px;

    }

    .privacy-bottom .btns .agree {width: 440rpx;}
</style>

3、应用形式

在 index.vue 中增加上面代码

<privacy-popup ref="privacyComponent" position="center" ></privacy-popup> 

4、如何勾销受权进行调试

  • 微信中「微信下拉 - 最近 - 最近应用的小程序」中删除小程序可勾销受权。
  • 开发者工具中「革除模拟器缓存 - 革除受权数据」可勾销受权。

原文链接:
uniapp 小程序隐衷协定弹窗组件

本文由 mdnice 多平台公布

正文完
 0