React Native Fetch 不能在本地使用 laravel API

我正在尝试在 react-native 中本地获取 laravel API。当我尝试使用远程 url 时,它可以工作,但不能与本地服务器一起使用。我正在使用 android studio 模拟器和


react-native => 0.59.8, 

laravel => 5.7

我的代码


 async submit() {


    //https://facebook.github.io/react-native/movies.json => this works


    try {

        let response = await fetch('localhost:8000/api/coins');

        let responseJsonData = await response.json();

        console.log(responseJsonData, 'data');

    } catch (e) {

        console.log(e, 'error')

    }

};

错误


05-20 14:46:08.167  4749  8885 I ReactNativeJS: { [TypeError: Network request failed]

05-20 14:46:08.167  4749  8885 I ReactNativeJS:   line: 24115,

05-20 14:46:08.167  4749  8885 I ReactNativeJS:   column: 31,

05-20 14:46:08.167  4749  8885 I ReactNativeJS:   sourceURL: 'http://10.0.2.2:8081/index.bundle?platform=android&dev=true&minify=false' }, 'error'


qq_笑_17
浏览 154回答 2
2回答

PIPIONE

这可能是一个问题iOS 在模拟器中运行,而 Android 在模拟器中运行。在您localhost:8000/api/coins localhost指向代码运行的环境。模拟器模拟真实设备,而模拟器只是模仿设备。所以localhost在 Android 上指向模拟的 Android 设备。而不是运行服务器的机器。解决方案 解决方案是替换localhost为您机器的 IP 地址。(例如:192.168.1.22)
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript