Sendbird SDK无法使用React Native

时间:2016-07-01 16:28:28

标签: node.js npm react-native sendbird

我正在关注使用react-native构建聊天应用程序的sendbird教程,当我尝试导入sendbird sdk时出现以下错误:

Unable to resolve module http from .../SendbirdSample/node_modules/sendbird/SendBird.min.js: 
Unable to find this module in its module map or any of the node_modules/http and its parent directories

我删除了node_modules文件夹并再次运行npm install,清理了npm cache并清除了watchman watch但无法修复它。

关于这个问题的任何想法?

更新:添加代码

main.js

import React from 'react';
import {
  StyleSheet,
  Navigator
} from 'react-native';

var Login = require('./components/login');
var Channels = require('./components/channels');

var ROUTES = {
  login: Login,
  channels: Channels
};

module.exports = React.createClass({
 renderScene: function(route, navigator) {
  var Component = ROUTES[route.name];
  return <Component route={route} navigator={navigator} />;
 },
 render: function() {
  return (
    <Navigator
      style = { styles.container }
      initialRoute={ {name:'login'} }
      renderScene={this.renderScene }
      configureScene={ () => { return Navigator.SceneConfigs.FloatFromRight; } } />
  );
}});

login.js

import React from 'react';

import {
  StyleSheet,
  Navigator
} from 'react-native';

var Login = require('./components/login');
var Channels = require('./components/channels');

var ROUTES = {
  login: Login,
  channels: Channels
};

module.exports = React.createClass({
  renderScene: function(route, navigator) {
   var Component = ROUTES[route.name];
    return <Component route={route} navigator={navigator} />;
  },
  render: function() {
      return (
       <Navigator
        style = { styles.container }
        initialRoute={ {name:'login'} }
        renderScene={this.renderScene }
        configureScene={ () => { return Navigator.SceneConfigs.FloatFromRight; } } />
  );
 }
});

channels.js

import React from 'react';

import {
  View,
  Text,
  StyleSheet
} from 'react-native';

var sendbird = require('sendbird');

module.exports = React.createClass({
  render: function() {
    return (
      <View style={styles.container}>
        <Text style={{color: '#fff'}}>Channels</Text>
      </View>
    );
  }
});

2 个答案:

答案 0 :(得分:6)

尝试使用早期版本的SendBird的JS SDK。根据我自己的测试,SDK v.2.4.19中引入了此问题。我的设置适用于sendbird@2.4.18和react-native@0.27.2。

补丁中突然出现此问题强烈暗示了SDK中的错误或引入了未记录的API更改(changelog),这基本上也是一个错误。


要安装特定版本的npm包:

npm i --save PACKAGE_NAME@MAJOR.MINOR.PATCH,例如

npm i --save sendbird@2.4.18

您可以通过运行

查看sdk的所有可用版本

npm info sendbird

答案 1 :(得分:1)

当我报告同样的问题时,我从Sendbird得到的官方消息。我没有尝试过新发布的3.0。所以不能说出来。

  

Harry Kim(SendBird)7月6日,01:51 PDT

     

感谢您与SendBird支持小组联系。

     

我们建议使用以下软件包正确运行SendBird。

"react-native": "0.20.0",
"react-native-button": "1.4.2",
"react-native-gifted-messenger": "0.0.18",
"react-native-gifted-spinner": "0.0.3",
"react-native-popup": "0.5.2",
"sendbird": "^2.4.20"
     

注意,哈利