- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我目前正在开发一个简单的 React Native,它向 Raspberry Pi3B 上托管的 Node.js 服务器发送打开或关闭 LED 的命令。
react native 代码:
import React from 'react';
import {StyleSheet, Text, View, Button} from 'react-native';
export default class App extends React.Component {
constructor(props){
super(props);};
led(couleur){
fetch('http://XXX.XXX.XXX.XXX:XXX/switchOnOff', {
method: 'POST',
headers: {
Accept: 'application/json',
'Content-Type': 'application/json',
},body: JSON.stringify({'couleur': couleur}),
}).catch((error) => {
console.error(error);
});
}
render() {
return (
<View>
<View style={styles.bleu}>
<Button title="Bleu" color='blue' onPress={() => this.led('bleu')}/>
</View>
</View>
);
}
}
在 Raspberry 上,我的 Node.js 服务器有以下内容:
var express = require('express');
var fs = require("fs");
var bodyParser = require('body-parser');
var Gpio = require('onoff').Gpio,
led14 = new Gpio(14, 'out');
var app = express();
app.use(bodyParser.json());
var allumer = false;
app.post('/switchOnOff', function (req, res) {
coul = req.body['couleur'];
console.log('working!');
var val = !allumer ? 1 : 0;
if (coul == 'bleu'){
led14.writeSync(val);}
led14.watch((err, mess) => {
if (err){throw err }})
allumer = !allumer;
}
});
var server = app.listen(8000, function () {
var host = server.address().address
var port = server.address().port
console.log("Example app listening at http://%s:%s", host, port)
})
奇怪的是,它连续工作了 5 次(我在服务器控制台中打印了五次“工作!”,并且 LED 灯打开/关闭)。
但是我收到以下错误:
从那时起,我无法使用 React Native 应用程序向服务器发送数据...
有人知道吗?
谢谢
最佳答案
实际上我明白了:
错误来自服务器端:我缺少一行代码res.end()
结束每个请求
修改服务器端代码:
app.post('/switchOnOff', function (req, res) {
coul = req.body['couleur'];
console.log('working!');
var val = !allumer ? 1 : 0;
if (coul == 'bleu'){
led14.writeSync(val);}
led14.watch((err, mess) => {
if (err){throw err }})
allumer = !allumer;
}
//#########solving line##########
res.end
});
关于几次成功迭代后,React Native 应用程序无法访问树莓派 3B 上的 Node.js 服务器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53932582/
(“ donut 派”)是否有最大切片数?我使用了 highchart(“ donut 派”)示例,但无法超过 10 个切片。请注意,内部切片“F”丢失了。下面是示例代码。 http://jsfidd
有谁知道如何找到 Samsung Galaxy 手机等同于 Settings.ACTION_ZEN_MODE_PRIORITY_SETTINGS 的常量?我有一个应用程序在三星用户单击应该将他们带到“
所以我很难弄清楚如何设置饼图/图例位置的布局。我希望图例左对齐,饼图右对齐。 40/60 百分比 -ish。 像这样: chart = new Highcharts.Chart({ c
我试图创建一种带有 4 个切片的圆形旋转木马,通过单击一个切片,它会扩展到约 2/3 的饼图,显示它的内容(另一个切片同样会收缩)基本上我是从 raphael “growing pie” 演示开始的
我尝试了所有可能的方式来提供 PIE.js 的路径,我使用的是 asp.net,这与在 java+tomcat 中的工作方式相同。我试过这样给 1)文件:css/home.css,css/pie/PI
cmds = ['time'] while True: inp = input('::> ') sinp = inp.split() if str(sinp[0]) in cm
我已经在 Raphael Google Groups 上看到过这个问题,但经过数小时的搜索后,在这里以及 Google 上,我似乎找不到解决方案。 我只是希望能够使用 jQuery 定位我的饼图(sv
这个问题在这里已经有了答案: Permission Denial: startForeground requires android.permission.FOREGROUND_SERVICE (5
我是一名优秀的程序员,十分优秀!