React Native的微信插件, 包括登录、分享
npm install react-native-wx --savernpm link react-native-wxlink成功命令行会提示
rnpm info Linking react-native-wx android dependency rnpm info Linking react-native-wx ios dependency#####ios a.打开XCode's工程中, 右键点击Libraries文件夹 ➜ Add Files to <...> b.去node_modules ➜ react-native-wx ➜ ios ➜ 选择 RCTWeChat.xcodeproj c.在工程Build Phases ➜ Link Binary With Libraries中添加libRCTWeChat.a
#####Android
// file: android/settings.gradle ... include ':react-native-wx' project(':react-native-wx').projectDir = new File(settingsDir, '../node_modules/react-native-wx/android') // file: android/app/build.gradle ... dependencies { ... compile project(':react-native-wx') } android/app/src/main/java/<你的包名>/MainActivity.java中,public class MainActivity之前增加:
import cn.reactnative.modules.wx.WeChatPackage;如果react-native版本 <0.18.0 .addPackage(new MainReactPackage())之后增加:
.addPackage(new WeChatPackage())如果react-native版本 >=0.18.0 在new MainReactPackage()之后增加
,new WeChatPackage()在工程target的Build Phases->Link Binary with Libraries中加入、libsqlite3.tbd、libc++、liz.tbd、CoreTelephony.framework
在Info->URL Types 中增加微信的scheme: Identifier 设置为weixin(这个拼写不能错哦), URL Schemes 设置为你注册的微信开发者账号中的APPID
如果react-native版本>=0.17.0, 在你工程的AppDelegate.m文件中添加如下代码:
#import "../Libraries/LinkingIOS/RCTLinkingManager.h" - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation { return [RCTLinkingManager application:application openURL:url sourceApplication:sourceApplication annotation:annotation]; } 如果升级有困难,react-native版本实在是<0.17.0, 在你工程的AppDelegate.m文件中添加如下代码:
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation { [[NSNotificationCenter defaultCenter] postNotificationName:@"RCTOpenURLNotification" object:nil userInfo:@{@"url": url.absoluteString}]; return YES; } <key>NSAppTransportSecurity</key> <dict> <key>NSAllowsArbitraryLoads</key> </true> </dict> <key>LSApplicationQueriesSchemes</key> <array> <string>weixin</string> <string>wechat</string> </array> 在android/app/build.gradle里,defaultConfig栏目下添加如下代码:
manifestPlaceholders = [ // 如果有多项,每一项之间需要用逗号分隔 WX_APPID: "微信的APPID" //在此修改微信APPID ] 如果react-native版本<0.18.0,确保你的MainActivity.java中有onActivityResult的实现:
private ReactInstanceManager mReactInstanceManager; @Override public void onActivityResult(int requestCode, int resultCode, Intent data){ super.onActivityResult(requestCode, resultCode, data); mReactInstanceManager.onActivityResult(requestCode, resultCode, data); }在你的包名相应目录下新建一个wxapi目录,并在该wxapi目录下新增一个WXEntryActivity类,该类继承自Activity(例如应用程序的包名为net.sourceforge.simcpux,则新添加的类的包名为net.sourceforge.simcpux.wxapi)
package net.sourceforge.simcpux.wxapi; // net.sourceforge.simcpux处为你的包名 import android.app.Activity; import android.os.Bundle; import cn.reactnative.modules.wx.WeChatModule; public class WXEntryActivity extends Activity{ @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); WeChatModule.handleIntent(getIntent()); finish(); } } import * as WechatAPI from 'react-native-wx'; 返回一个Promise对象
返回一个Promise对象
// 登录参数 config : { scope: 权限设置, // 默认 'snsapi_userinfo' }返回一个Promise对象。成功时的回调为一个类似这样的对象:
{ "code": "", "appid": "", "lang": "", "country": "", }分享到朋友圈
分享到好友
// 分享文字 { type: 'text', text: 文字内容, }// 分享图片 { type: 'image', imageUrl: 图片地址, title : 标题, description : 描述, }// 分享网页 { type: 'news', title : 标题, description : 描述, webpageUrl : 链接地址, imageUrl: 缩略图地址, }// 登录参数 data : { partnerId: "", prepayId: "", nonceStr: "", timeStamp: "", package: "", sign: "", }返回一个Promise对象。成功时的回调为一个类似这样的对象:
{ errCode: "", errMsg: "", appid: "", returnKey: "", }