搜索
javascript - 微信 js 分享接口 能不能卸载 windows.onload中
迷茫
迷茫 2017-04-10 15:32:30
[JavaScript讨论组]

最近公司要做一个微信分享的功能,现在已经完成了基本的开发工作,现在想把js接口在进行封装,更简单。现在放到window.onload,自己定义就无效了

    var appId="";
    var timestamp="";
    var nonceStr="";
    var signature="";
    var weixinTitle = "";
    var weixinLink = "";
    var weixinImageUrl = "";
    var weixinDesc = "";

    var data1 = {};

    function weixinC(){
        function config(configObj){
            data1['url'] = configObj.url;
            weixinTitle = configObj.title;
            weixinLink = configObj.link;
            weixinImageUrl = configObj.imageUrl;
            weixinDesc = configObj.desc;
        }

        return {
                config:config
        }
    }

    var weixinShareUrl = weixinC();
    //当前页面路径  标题  链接   图片链接   内容
    function WeiXinShare(){
        $.ajax({
            "url": ctx+'/weixin/weixinShare',
            "type": "POST",
            "dataType": "json",
            "data": data1,
             async:true, 
            success: function(result) {
                //var obj = JSON.parse(result.toString());
                appId = result.data.appId;
                timestamp = result.data.timestamp;
                nonceStr = result.data.nonceStr;
                signature = result.data.signature;
            }
         });
    }

window.onload = function (){
    WeiXinShare();
    wx.config({
        debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
        appId: appId, // 必填,公众号的唯一标识
        timestamp: timestamp, // 必填,生成签名的时间戳
        nonceStr: nonceStr, // 必填,生成签名的随机串
        signature: signature,// 必填,签名,见附录1
        jsApiList: ['onMenuShareTimeline','onMenuShareAppMessage'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
    });
    //config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
    //获取“分享到朋友圈”按钮点击状态及自定义分享内容接口
    wx.ready(function(){
        //获取“分享到朋友圈”按钮点击状态及自定义分享内容接口
        wx.onMenuShareTimeline({
            title: weixinTitle, // 分享标题
            desc: weixinDesc, // 分享描述
            link: weixinLink, // 分享链接
            imgUrl: weixinImageUrl, // 分享图标
            success: function () { 
                // 用户确认分享后执行的回调函数
            },
            cancel: function () { 
                // 用户取消分享后执行的回调函数
            }
        });
        //获取“分享给朋友”按钮点击状态及自定义分享内容接口
        wx.onMenuShareAppMessage({
            title: weixinTitle, // 分享标题
            desc: weixinDesc, // 分享描述
            link: weixinLink, // 分享链接
            imgUrl: weixinImageUrl, // 分享图标
            type: '', // 分享类型,music、video或link,不填默认为link
            dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空
            success: function () { 
                // 用户确认分享后执行的回调函数
            },
            cancel: function () { 
                // 用户取消分享后执行的回调函数
            }
        });
    });

    // config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
    wx.error(function(res){
        alert("分享失败");
    });
}   


//初始化数据
weixinShareUrl.config({
    url:"http://www.abazc.com/hpzc-mobile/mtrade/accountCenter",
    title:"4324324",
    link:"http://www.baidu.com/",
    imageUrl:"",
    desc:"123123"
})
迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

全部回复(0)
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号