- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
编辑 1
所以我现在已经按照建议更新了 projectorSaga 函数以使用 yield call(),但我现在每次调用该函数时都会收到以下错误,我认为这是由于我嵌套函数和返回 promise 的方式所致不是返回 promise 的函数,但我对如何重组它来修复它有点不知所措。
redux-saga error: uncaught at check
call: argument [object Promise] is not a function
[14:57:43.351] [verbose] Error: call: argument [object Promise] is not a function
这里是update saga的代码,其他功能依旧如下。
import { put, takeEvery, call } from 'redux-saga/effects';
import * as pjControl from '../../pjcontrol/pjControl';
import { TURNON, TURNOFF, SENDCOMMAND, SHUTTERCLOSE, SHUTTEROPEN } from '../actions/actionTypes';
const log = require('electron-log');
const ip = '192.168.100.100';
const port = 3629;
const model = 'L1500';
function* sendCommand(payload) {
yield put({ type: 'SENDING COMMAND', payload });
try {
let response;
const command = payload.payload.command;
if (command === TURNON) {
response = yield call(pjControl.turnOn(ip, port, model));
} else if (command === TURNOFF) {
response = yield call(pjControl.turnOff(ip, port, model));
} else if (command === SHUTTERCLOSE) {
response = yield call(pjControl.shutterClose(ip, port, model));
} else if (command === SHUTTEROPEN) {
response = yield call(pjControl.shutterOpen(ip, port, model));
} else {
throw Error('Unknwon Command');
}
log.verbose(response);
yield put({ type: 'SEND_COMMAND_SUCCEEDED', response });
} catch (e) {
log.verbose(e);
yield put({ type: 'SEND_COMMAND_FAILED', e });
}
}
export default function* projectorSetSaga() {
yield takeEvery(SENDCOMMAND, sendCommand);
}
原创
我刚刚开始尝试在我一直在使用的 Electron 应用程序中使用 Redux-Saga,但我在使用我的生成器函数之一时遇到了问题。我怀疑是我不理解 say 函数和回调等的嵌套,但到目前为止,我已经以多种方式尝试过这一点,但没有任何区别。
问题的奇怪之处在于 sendCommand 中的初始 yield 确实导致事件出现在 Redux 中。此外,我的日志命令确实会在我期望的时候以正确的值被调用。如果连接超时,将调用 catch 中的日志,但 throw 命令都不会出现在 Redux 中。
这是我的根传奇:
import { all, call } from 'redux-saga/effects';
import projectorGetSaga from './projectorGetSaga';
import projectorSetSaga from './projectorSetSaga';
export default function* rootSaga() {
yield all([
call(projectorGetSaga),
call(projectorSetSaga),
]);
}
这是我正在努力解决的 projectorSetSaga。
import { put, takeEvery } from 'redux-saga/effects';
import * as pjControl from '../../pjcontrol/pjControl';
import { TURNON, TURNOFF, SENDCOMMAND, SHUTTERCLOSE, SHUTTEROPEN } from '../actions/actionTypes';
const log = require('electron-log');
const ip = '192.168.100.100';
const port = 3629;
const model = 'L1500';
function* sendCommand(payload) {
yield put({ type: 'SENDING COMMAND', payload });
try {
let response;
const command = payload.payload.command;
if (command === TURNON) {
response = yield pjControl.turnOn(ip, port, model);
} else if (command === TURNOFF) {
response = yield pjControl.turnOff(ip, port, model);
} else if (command === SHUTTERCLOSE) {
response = yield pjControl.shutterClose(ip, port, model);
} else if (command === SHUTTEROPEN) {
response = yield pjControl.shutterOpen(ip, port, model);
} else {
throw Error('Unknwon Command');
}
log.verbose(response);
yield put({ type: 'SEND_COMMAND_SUCCEEDED', response });
} catch (e) {
log.verbose(e);
yield put({ type: 'SEND_COMMAND_FAILED', e });
}
}
export default function* projectorSetSaga() {
yield takeEvery(SENDCOMMAND, sendCommand);
}
这是 saga 正在调用的函数的其余代码,因为它可能是相关的,我可能完全误解了需要返回异步函数/promises 等的方式。
sendCommand函数调用的PJ Control函数如下。
import * as epsonControl from './epson/epsonControl';
import { manufacturerlLookup, commandLookup } from './pjLookups';
function sendCommand(ip, port, model, command, input) {
const manufacturer = manufacturerlLookup(model);
const mappedCommand = commandLookup(manufacturer, command, input);
switch (manufacturer) {
case 'epson':
return epsonControl.sendCommand(ip, port, mappedCommand);
default:
return null;
}
}
exports.turnOn = (ip, port, model) => sendCommand(ip, port, model, 'PWR ON');
exports.turnOff = (ip, port, model) => sendCommand(ip, port, model, 'PWR OFF');
exports.shutterOpen = (ip, port, model) => sendCommand(ip, port, model, 'MUTE OFF');
exports.shutterClose = (ip, port, model) => sendCommand(ip, port, model, 'MUTE ON');
exports.setInput = (ip, port, model, input) => sendCommand(ip, port, model, 'SOURCE', input);
exports.getPowerStatus = (ip, port, model) => sendCommand(ip, port, model, 'PWR?');
exports.getShutterStatus = (ip, port, model) => sendCommand(ip, port, model, 'MUTE?');
exports.getInputStatus = (ip, port, model) => sendCommand(ip, port, model, 'SOURCE?');
最后,实际的异步函数,实际上是通过 return/throw 返回一个 promise。
exports.sendCommand = async (host, port, command) => {
log.info(`sending command ${command} to ${host}`);
// throw new Error('Oh dear!');
// Set a time to cancel the operation if the connection times out
const mergedCommand = `${command}\r`;
// Create a new client
const socket = new net.Socket();
socket.setTimeout(1000);
const client = new PromiseSocket(socket);
await client.connect({ host, port });
await client.write(buildBuffer(handshake));
client.stream.on('data', (data) => {
if (data.toString() === response) {
log.verbose(`Got handshake, sending command ${command}`);
client.write(buildBuffer(mergedCommand));
} else if (data.toString() === ':') {
// log.verbose('command executed successfully, disconnecting');
sendStatus(data.toString(), host);
client.end();
return (true, 'command');
} else {
const respose = data.toString().substring(0, data.toString().length - 2);
// log.verbose(`got status ${response} disconnecting`);
sendStatus(respose, host);
client.end();
return (true, 'command', data);
}
});
};
最佳答案
我认为您正在yielding
(暂停)生成器函数而不调用 next。 Saga 有这方面的功能。例如,不是在函数调用时产生,而是在 saga 函数 call
上产生。
所以应该是:
try {
let response;
const command = payload.payload.command;
if (command === TURNON) {
response = yield call([pjControl,'turnOn'],ip, port, model);
}
...
关于javascript - 无法让 Redux 在生成器函数中运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48580846/
我使用以下代码和嵌套生成器迭代文本文档并使用 get_train_minibatch() 返回训练示例。我想保留( pickle )生成器,这样我就可以回到文本文档中的相同位置。但是,您不能 pick
在本教程中,您将借助示例了解 JavaScript 生成器。在 JavaScript 中,生成器提供了一种使用函数和迭代器的新方法。 使用生成器, 您可以从函数内部的任何位置停止执行函数 并从
LESS is very cool .我一直想知道是否有任何好的 html 生成器可以让我更轻松地编写表单或做其他事情。除了 html,是否有一些类似的东西? 最佳答案 已尝试 Haml ? 从它的网
前言 如果是做python或者其他语言的小伙伴,对于生成器应该不陌生。但很多php开发者或许都不知道生成器这个功能,可能是因为生成器是php 5.5.0才引入的功能,也可以是生成器作用不是很明显。
我正在尝试编写一个使用生成器语法生成日期时间列表的函数: let dateRange = let endDate = System.DateTime.Parse("6/1/2010")
我遇到了一些看起来像的代码: [func(val) for val in iterable] 有一个可迭代对象(在我的例子中是一个生成器),用户想要为其副作用调用每个值的函数(例如 func 可以只是
Delphi 有内置的东西来生成 UUID 吗? 最佳答案 program Guid; {$APPTYPE CONSOLE} uses SysUtils; var Uid: TGuid; Result
我正在深入研究 javascript 生成器,但我真的很困惑。 我使用 node@0.11.x 运行此示例: function find() { process.nextTick(functi
有人知道一些关于如何为 hibernate 创建自定义 ID 生成器的好教程吗? 最佳答案 在 Google 上粗略搜索“hibernate 自定义 id 生成器教程”发现了以下可能性。我排除了那些看
我正在关注 Python 大师 David Beazley 的幻灯片。它指出“生成器也用于并发。这是一个示例: from collections import deque def countdown(
我有一个生成事件的生成器,我想用可以从 API 获取的附加元数据来丰富它。 某些事件具有与其链接的对象 ID,而其他事件则具有对象的哈希值,但不能同时具有两者。我无法根据哈希获取对象 id,我只能执行
假设我有一个自定义类: public class CustomClass { private String name; private String data; public
我正在考虑实现一个函数来在 SQL 请求中“构建”WHERE 子句,如下所示: "SELECT * FROM table $where" 使用如下所示的循环构建 $where: $arr=array(
我正在寻找执行此操作的标准函数: def Forever(v): while True: yield v 这看起来太琐碎了,我不敢相信没有标准版本。 就此而言,有人知道指向所有标准生成器函
我知道这个网站上有几个非常相似的相关问题,但是在看了这部剧之后,我相信这个问题本身就是独一无二的。如果有人能找到并提供证据证明我的问题完全被骗了,我会自己撤回它(所以请不要否决这个!)。 我是 Jav
void __fastcall TForm1::Button1Click(TObject *Sender) { int size = MemoEnter->GetTextLen() + 1;
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我试图在我的生成器的以下两个定义之间做出决定。哪个更好?哪个“更像 python ”?无论如何,有没有办法减轻每一个的缺点? def myGenerator1(howMany): result
我有一个 Python 生成器 lexg,它在每次迭代时生成一个列表。该代码似乎在传统的 for 循环意义上工作,即 for i in lexg(2,2): print(i) 产生: [2, 0] [
我希望这不会超出 Python 生成器的能力,但我想构建一个这样,每次调用该函数时,它都会返回下一分钟直到结束时间。 因此该函数读取开始时间和结束时间,并以分钟为单位返回时间,直到涵盖其间的所有时间。
我是一名优秀的程序员,十分优秀!