Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/spring-mvc/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
React native 使用react native共享链接和字符串无效_React Native_Share - Fatal编程技术网

React native 使用react native共享链接和字符串无效

React native 使用react native共享链接和字符串无效,react-native,share,React Native,Share,在使用中,我遇到了这个错误。我的代码可以在下面看到,我不完全确定它的意思 元素类型无效:需要字符串(对于内置组件)或类/函数(对于复合组件),但得到:未定义。检查选项卡的渲染方法 Share.js import React,{Component}来自'React'; 进口{ 评估学, 样式表, 文本, 可触摸不透明度, 看法 剪贴板, 蟾蜍, AlertIOS, 站台 }从“反应本机”; 从'react native Share'导入共享,{ShareSheet,Button}; 类TestSh

在使用中,我遇到了这个错误。我的代码可以在下面看到,我不完全确定它的意思

元素类型无效:需要字符串(对于内置组件)或类/函数(对于复合组件),但得到:未定义。检查
选项卡的渲染方法

Share.js
import React,{Component}来自'React';
进口{
评估学,
样式表,
文本,
可触摸不透明度,
看法
剪贴板,
蟾蜍,
AlertIOS,
站台
}从“反应本机”;
从'react native Share'导入共享,{ShareSheet,Button};
类TestShare扩展组件{
建造师(道具){
超级(道具);
此.state={
可见:假
}
}
onCancel(){
控制台日志(“取消”)
this.setState({visible:false});
}
onOpen(){
控制台日志(“打开”)
this.setState({visible:true});
}
render(){
让共享选项={
标题:“反应本机”,
信息:“Hola mundo”,
url:“http://facebook.github.io/react-native/",
主题:“共享链接”//用于电子邮件
};
让shareImageBase64={
标题:“反应本机”,
信息:“Hola mundo”,
url:REACT_图标,
主题:“共享链接”//用于电子邮件
};
返回(
{
Share.open(shareImageBase64);
}}>
简单共享映像库64
{
公开(股票期权);
}}>
简单共享
共享用户界面组件
{
这个。onCancel();
设置超时(()=>{
Share.shareSingle(Object.assign)(shareOptions{
“社交”:“推特”
}));
},300);
}}>推特
{
这个。onCancel();
设置超时(()=>{
Share.shareSingle(Object.assign)(shareOptions{
“社交”:“facebook”
}));
},300);
}}>脸谱网
{
这个。onCancel();
设置超时(()=>{
Share.shareSingle(Object.assign)(shareOptions{
“社交”:“whatsapp”
}));
},300);
}}>Whatsapp
{
这个。onCancel();
设置超时(()=>{
Share.shareSingle(Object.assign)(shareOptions{
“社交”:“谷歌+”
}));
},300);
}}>谷歌+
{
这个。onCancel();
设置超时(()=>{
Share.shareSingle(Object.assign)(shareOptions{
“社交”:“电子邮件”
}));
},300);
}}>电子邮件
{
这个。onCancel();
设置超时(()=>{
如果(共享选项的类型[“url”]!==未定义){
剪贴板.setString(shareOptions[“url]”);
如果(Platform.OS==“android”){
ToastAndroid.show('Link copiado al portapapeles',ToastAndroid.SHORT);
}else if(Platform.OS==“ios”){
AlertIOS.alert('Link copiado al portapapeles');
}
}
},300);
}}>复制链接
{
这个。onCancel();
设置超时(()=>{
Share.open(共享选项)
},300);
}}>更多
);
}
}
const styles=StyleSheet.create({
容器:{
弹性:1,
为内容辩护:“中心”,
对齐项目:“居中”,
背景颜色:“#F5FCFF”,
},
说明:{
玛金托普:20,
marginBottom:20,
},
});
//推特图标
常量推特图标=“数据:图像/png;base64,IVBORW0KGGOAAAANSUHEUGAAADWAAAA8CAMAAANAIAABVFBMVEUAAAA//8AnuwAnOsAneoAm+oAm+oAm+oAm+kAnuwAmf8An+0AQTUAKU0ANEAAM+oAm+OANESAAQV8AN+oAm+OAN98ANOAM+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+0ANOAM+0ANOAM+0Av/8Am+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+MO+MOA+MOA+MOA+MUKAMUKAMUKANU+MO+MO+MO+MO+MO+MO+MOA+MO+MO+MO(A+momomomoamamamam+oAm+oAm+oAm+oAm+oAm+oAm+mom+am++卡姆+卡姆(amamamamamam+oamumumumumumumumumumumumumumuwawawam+oAm+oamomo+oAn+oAn+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oale0+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+oAm+0+oAm+oAm+oAm+oAm+T5OL9Z2.中国的一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市,一个城市一个城市,一个城市一个城市,一个城市一个城市,一个城市一个城市一个城市一个城市一个城市一个城市一个城市一个城市一个城市一个城市一个城市一个城市一个城市一个城市一个城市一个城市一个城市一个城市一个城市一个城市A3MISYRDC1WTTHC9EBGW6+6+KKR9这两个数字都是一个数字。这两个数字都是一个数字。这两个数字是一个数字,一个数字是一个数字,一个数字是一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,一个数字,RU5ERKJGG==";
//facebook图标
const FACEBOOK_图标=“数据:图像/png;base64,IVBORW0KGGOAAAANSUHEUGAADWAAAA8CAMAAANIILAAAAAAAAAAYFBM4VV/JL0O4VSEGBNQPUHW4W0GAX5GAX5GAX5GAX5GAX5GAX5GAX5GAX5GAX5GAX5GAX5KAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CAX5CA8QD6CY94Oger8StmViozQllNexW1mmR5OqFDGGS378WXGZVWO5JIZ2WfNjxaboufdffqaaaBjru5erkJggg==”;
//whatsapp图标
const WHATSAPP_ICON=“数据:图像/png;base64,IVBorW0KggoaaaAnsuhueugaaaaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAaAa
import React, { Component } from 'react';
import {
  AppRegistry,
  StyleSheet,
  Text,
  TouchableOpacity,
  View,
  Clipboard,
  ToastAndroid,
  AlertIOS,
  Platform
} from 'react-native';
import Share, {ShareSheet, Button} from 'react-native-share';

class TestShare extends Component {
  constructor(props) {
    super(props);
    this.state = {
      visible: false
    }
  }
  onCancel() {
    console.log("CANCEL")
    this.setState({visible:false});
  }
  onOpen() {
    console.log("OPEN")
    this.setState({visible:true});
  }
  render() {

    let shareOptions = {
      title: "React Native",
      message: "Hola mundo",
      url: "http://facebook.github.io/react-native/",
      subject: "Share Link" //  for email
    };

    let shareImageBase64 = {
      title: "React Native",
      message: "Hola mundo",
      url: REACT_ICON,
      subject: "Share Link" //  for email
    };

    return (
      <View style={styles.container}>


        <TouchableOpacity onPress={()=>{
          Share.open(shareImageBase64);
        }}>
          <View style={styles.instructions}>
            <Text>Simple Share Image Base 64</Text>
          </View>
        </TouchableOpacity>

        <TouchableOpacity onPress={()=>{
          Share.open(shareOptions);
        }}>
          <View style={styles.instructions}>
            <Text>Simple Share</Text>
          </View>
        </TouchableOpacity>

        <TouchableOpacity onPress={this.onOpen.bind(this)}>
          <View style={styles.instructions}>
            <Text>Share UI Component</Text>
          </View>
        </TouchableOpacity>

        <ShareSheet visible={this.state.visible} onCancel={this.onCancel.bind(this)}>
          <Button iconSrc={{ uri: TWITTER_ICON }}
                  onPress={()=>{
              this.onCancel();
              setTimeout(() => {
                Share.shareSingle(Object.assign(shareOptions, {
                  "social": "twitter"
                }));
              },300);
            }}>Twitter</Button>
          <Button iconSrc={{ uri: FACEBOOK_ICON }}
                  onPress={()=>{
              this.onCancel();
              setTimeout(() => {
                Share.shareSingle(Object.assign(shareOptions, {
                  "social": "facebook"
                }));
              },300);
            }}>Facebook</Button>
          <Button iconSrc={{ uri: WHATSAPP_ICON }}
                  onPress={()=>{
              this.onCancel();
              setTimeout(() => {
                Share.shareSingle(Object.assign(shareOptions, {
                  "social": "whatsapp"
                }));
              },300);
            }}>Whatsapp</Button>
          <Button iconSrc={{ uri: GOOGLE_PLUS_ICON }}
                  onPress={()=>{
              this.onCancel();
              setTimeout(() => {
                Share.shareSingle(Object.assign(shareOptions, {
                  "social": "googleplus"
                }));
              },300);
            }}>Google +</Button>
          <Button iconSrc={{ uri: EMAIL_ICON }}
                  onPress={()=>{
              this.onCancel();
              setTimeout(() => {
                Share.shareSingle(Object.assign(shareOptions, {
                  "social": "email"
                }));
              },300);
            }}>Email</Button>
          <Button
            iconSrc={{ uri: CLIPBOARD_ICON }}
            onPress={()=>{
              this.onCancel();
              setTimeout(() => {
                if(typeof shareOptions["url"] !== undefined) {
                  Clipboard.setString(shareOptions["url"]);
                  if (Platform.OS === "android") {
                    ToastAndroid.show('Link copiado al portapapeles', ToastAndroid.SHORT);
                  } else if (Platform.OS === "ios") {
                    AlertIOS.alert('Link copiado al portapapeles');
                  }
                }
              },300);
            }}>Copy Link</Button>
          <Button iconSrc={{ uri: MORE_ICON }}
            onPress={()=>{
              this.onCancel();
              setTimeout(() => {
                Share.open(shareOptions)
              },300);
            }}>More</Button>
        </ShareSheet>
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#F5FCFF',
  },
  instructions: {
    marginTop: 20,
    marginBottom: 20,
  },
});

//  twitter icon
const TWITTER_ICON = "";

//  facebook icon
const FACEBOOK_ICON = "";

//  whatsapp icon
const WHATSAPP_ICON = "";

//  gplus icon
const GOOGLE_PLUS_ICON = "";

//  email icon
const EMAIL_ICON = "";

//  clipboard icon
const CLIPBOARD_ICON = "";

//  more icon
const MORE_ICON = "";


const REACT_ICON = '';

AppRegistry.registerComponent('TestShare', () => TestShare);
[![import React, { Component } from 'react'
import { TabBarIOS } from 'react-native'

import Share from '../components/Share'
import SaveQuote from '../components/SaveQuote'
import Home from '../containers/navRootContainer'
import MoreMenu from '../components/MoreMenu'

class Tabs extends Component {
  _changeTab (i) {
    const { changeTab } = this.props
    changeTab(i)
  }
  _renderTabContent (key) {
    switch (key) {
      case 'home':
        return <Home />
      case 'share':
        return <Share />
      case 'savequote':
        return <SaveQuote />
      case 'moremenu':
        return <MoreMenu />
    }
  }
  render () {
    const tabs = this.props.tabs.tabs.map((tab, i) => {
      return (
        <TabBarIOS.Item 
          key={tab.key}
          icon={tab.icon}
          selectedIcon={tab.selectedIcon}
          title={tab.title}
          onPress={() => this._changeTab(i)}
          selected={this.props.tabs.index === i}>
          {this._renderTabContent(tab.key)}
        </TabBarIOS.Item>
      )
    })
    return (
      <TabBarIOS tintColor='white' barTintColor="black">
        {tabs}
      </TabBarIOS>
    )
  }
}

export default Tabs][2]][2]