- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 reducer 中更新此上下文中的状态的更好方法是什么?
case DELETE_INTEREST:
let deleteInterests = state.user.interests;
let index = deleteInterests.findIndex(i => i == action.payload);
deleteInterests.splice(index, 1);
return { ...state, user: { ...state.user, interests: deleteInterests } };
ESLint 不喜欢在 reducer 内的 case block 内使用 let 语句,得到:
eslint: no-case-declaration - unexpected lexical declaration in case block
最佳答案
ESLint doesn't like let statements inside case blocks inside areducer, Why?
不鼓励这样做,因为它会导致变量处于当前case
范围之外。通过使用 block ,您可以将变量的范围限制在该 block 内。
使用 {}
创建带有大小写的 block 作用域,如下所示:
case DELETE_INTEREST: {
let .....
return (...)
}
检查此片段:
function withOutBraces() {
switch(1){
case 1:
let a=10;
console.log('case 1', a);
case 2:
console.log('case 2', a)
}
}
function withBraces() {
switch(1){
case 1: {
let a=10;
console.log('case 1', a);
}
case 2: {
console.log('case 2', a)
}
}
}
console.log('========First Case ============')
withOutBraces()
console.log('========Second Case ============')
withBraces();
要从数组中删除元素,请使用 array.filter ,因为splice将对原始数组进行更改。像这样写:
case DELETE_INTEREST:
let deleteInterests = state.user.interests;
let newData = deleteInterests.filter(i => i !== action.payload);
return { ...state, user: { ...state.user, interests: newData } };
关于reactjs - eslint : no-case-declaration - unexpected lexical declaration in case block,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50752987/
我正在阅读有关 C# 和闭包的各种信息 articles ,Jon Skeet 的精彩“C# in Depth”,我看到像“C# 和 ruby 实现词法闭包”这样的陈述。 为什么作者要包含“词汇”
我有两个编辑器实例。一个是可编辑的第二个只读,用于预览用户输入的内容我在这些编辑器之间复制了编辑器状态 - 没有任何问题但我想当第一个编辑器为空时隐藏第二个编辑器。我正在尝试类似的方法,但它总是返回
我正在使用 Flex 构建自己的语言,但我想知道一些事情: 为什么要使用词法分析器? 他们会帮我做点什么吗? 他们是强制性的吗? 最佳答案 词法分析有助于简化解析,因为词位可以被视为抽象实体而不是具体
考虑到一个二进制数据(视频/图像/音频/可执行文件)可以看作是一长串随机字节, 当数据采用特殊格式(SQL、数据库中的 BOLB、MP3、JSON、XML 等)时,解析器如何知道特殊字符(或字符序列,
我对 javascript 中的 this 有疑问。 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operato
我使用术语“词法编码”是因为我没有更好的编码。 与字母相反,单词可以说是交流的基本单位。 Unicode 尝试为所有已知字母表的每个字母分配一个数值。对一种语言来说是字母,对另一种语言来说是字形。 U
我一直在用 Java 编写一个语音识别程序,只是为了看看它是如何工作的。直到一天前一切都工作得很好。我不知道发生了什么,因为我没有更改代码中的任何内容。 由于出现词汇错误,我想我只需要粘贴我的语法文件
在调试一些较旧的 perl 代码时,我使用 perl critic 来发现错误。我经常偶然发现这个“循环迭代器不是词法”策略: Perl::Critic::Policy::Variables::Req
在 perdoc Socket页,他们使用全局文件句柄作为套接字。 但是如果我在子进程调用的子例程中创建一个套接字,使用词法文件句柄仍然使用 Socket 是否更好? 像这样: use strict;
我正在尝试为我出于个人原因而设计的 C/C++/C#/Java/D 之类的编程语言编写扫描仪。对于这个任务,我使用 Ragel 来生成我的扫描仪。我无法准确理解许多操作符何时触发 Action ,可能
我是 AI 学生,我们使用 JavaCC。 我是新手。我正在尝试简单的例子,但我有一些错误。 1)我从它的网站下载了 JavaCC 0.6 2)我把它解压到C盘 3)我将此代码写在扩展名为“.jj”的
在@lexical/react中,在没有依赖数组的useEffect中注册编辑器命令是否会带来重大损失(性能或其他)? useEffect(() => { const unsubscribe =
我有一个词法编辑器,需要将其序列化为 html,以便我可以将其嵌入到电子邮件模板中。 使用 $generateHtmlFromNodes 函数时,我不断遇到以下错误: Error: Unable to
在经典的编译器理论中,前两个阶段是词法分析和语法分析。他们正在筹备中。词法分析将标记识别为解析的输入。 但是我遇到了一些在词法分析中很难被正确识别的情况。例如下面关于C++模板的代码: map> >>
let textBytes = ctypes.uint8_t("hello"); let a = new SECItem; a.type = siBuffer; a.data = textBytes.
我有4条规则 rule1: match variable rule2: match Float rule3: match Integer rule4: [ \t] ; //skipping space
如果您查看 original Wordnet search并选择“显示选项:显示词汇文件信息”,您将看到一个非常有用的单词分类,称为 词汇文件 .例如,对于“填充”,我们有: S: (n) fi
我已经多次看到术语“词法变量”,主要是在闭包的上下文中。 Paul Graham 在他关于 Lisp 的书中使用这个术语来指代使用 let 表达式定义的变量。 我知道词法作用域是静态作用域的另一个名称
应用程序版本 Elasticsearch:v.7.1 Laravel:v5.8 操作系统版本:Ubuntu 18(服务器)/ Windows 10(开发PC) Elasticsearch搜索API的“
我想以 myObj 作为其运行范围来调用 myObj.sayHello。我了解绑定(bind),它工作得很好。 var myObj = {"name1":"BP", "sayHell
我是一名优秀的程序员,十分优秀!