React Js 위 챗 공유 패키지
http://blog.csdn.net/wyk304443164
직접 원본 코드 올 리 기:
/**
* Created by wuyakun on 2017/5/23.
*/
import Fetch from './FetchIt';
import API_URL from './url';
import Share from './Share';
let wxUtils = {};
//////////////////////////////////////////////////////////////////////////////////////
//
//
//
//////////////////////////////////////////////////////////////////////////////////////
/**
getshareinfo?type=
type :goods team
id id
tid ID
* @param config
* @param shareInfo {imgUrl,title,description,link}
*/
function share2wx(config, shareInfo) {
const share = new Share({
appid: config.appid, // ,
timestamp: config.timestamp, // ,
nonceStr: config.nonceStr, // ,
signature: config.signature, // ,
});
share.init(Object.assign({}, shareInfo));
}
function getConfig(shareInfo) {
let href = window.location.href.split('#')[0];
const url = encodeURIComponent(href /*window.location.href*/);
Fetch.get(`${API_URL.mobile.signature_path}?url=${url}`).then(data => {
share2wx(data, shareInfo);
});
}
/**
* @param shareInfo
*/
wxUtils.share = function (shareInfo) {
getConfig(shareInfo);
};
//////////////////////////////////////////////////////////////////////////////////////
//
//
//
//////////////////////////////////////////////////////////////////////////////////////
/**
* Menu
* @param open
*/
wxUtils.optionMenu = function (open = true) {
if (open) {
openOptionMenu();
} else {
disabledOptionMenu();
}
};
/**
*
*/
function disabledOptionMenu() {
if (typeof WeixinJSBridge === "undefined") {
if (document.addEventListener) {
document.addEventListener('WeixinJSBridgeReady', onBridgeReady(true), false);
} else if (document.attachEvent) {
document.attachEvent('WeixinJSBridgeReady', onBridgeReady(true));
document.attachEvent('onWeixinJSBridgeReady', onBridgeReady(true));
}
} else {
onBridgeReady(true);
}
}
/**
* menu
*/
function openOptionMenu() {
if (typeof WeixinJSBridge === "undefined") {
if (document.addEventListener) {
document.addEventListener('WeixinJSBridgeReady', onBridgeReady(false), false);
} else if (document.attachEvent) {
document.attachEvent('WeixinJSBridgeReady', onBridgeReady(false));
document.attachEvent('onWeixinJSBridgeReady', onBridgeReady(false));
}
} else {
onBridgeReady(false);
}
}
function onBridgeReady(disable = true) {
if (typeof WeixinJSBridge !== "undefined") WeixinJSBridge.call(disable ? 'hideOptionMenu' : 'showOptionMenu');
}
/**
*
* @param disable
*/
wxUtils.disabledToolbar = function (disable = true) {
document.addEventListener('WeixinJSBridgeReady', function onBridgeReady() {
// API
WeixinJSBridge.call(disable ? 'hideToolbar' : 'showToolbar');
});
};
export default wxUtils;
//
function Share(config) {
wx.config({
debug: false, //
appId: config.appid, // ,
timestamp: config.timestamp, // ,
nonceStr: config.nonceStr, // ,
signature: config.signature, // , , 1
jsApiList: ['onMenuShareTimeline', 'onMenuShareAppMessage', 'onMenuShareWeibo'], // , JS , JS 2
});
}
Share.prototype = {
constructor: Share,
init(config) {
this.imgUrl = config.imgUrl;
this.link = config.link;
// this.musicPath = config.musicPath;
this.description = config.description;
this.title = config.title;
wx.ready(() => {
// if (this.musicPath) {
// document.getElementById('musicIcon').play();
// }
this.toFriend();
this.toTimeline();
});
wx.error(res => {
console.log(`${res}`);
});
},
toFriend() {
wx.onMenuShareAppMessage({
imgUrl: this.imgUrl,
link: this.link,
title: this.title,
desc: this.description,
success: function () {
//
},
});
},
toTimeline() {
wx.onMenuShareTimeline({
imgUrl: this.imgUrl,
link: this.link,
title: this.title,
desc: this.description,
success: function () {
//
},
});
},
};
export default Share;
//
BaseComponent.wxUtils.optionMenu(true);
BaseComponent.wxUtils.share({
imgUrl: activityData.sharePicUrl,
title: activityData.shareTitle,
description: activityData.shareContent,
link: url,
});
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Bitrise에서 배포 어플리케이션 설정 테스트하기이 글은 Bitrise 광고 달력의 23일째 글입니다. 자체 또는 당사 등에서 Bitrise 구축 서비스를 사용합니다. 그나저나 며칠 전 Bitrise User Group Meetup #3에서 아래 슬라이드를 발표했...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.