草庐IT

while语句

全部标签

javascript - 使用 ES6 import 语句时,有没有办法防止未定义的项目?

import{foobar1,foobar2,foobor3,//typo!thiskeydoesn'texistinthemodule.}from'./module_file.js'console.log(foobar1,foobar2,foobar3)//EXPLODES我在使用新的ES6样式导入语句时犯的最常见的愚蠢错误之一是我在对象解构中的一个键中有错字。我想不出有哪个实例是我希望解构赋值中的值是undefined的。如果我尝试导入的其中一项未定义,是否有任何方法可以强制导入语句快速失败?即:import{doesntExistInModule//EXPLODENOW!???}

javascript - 自动分号插入和返回语句

这个问题在这里已经有了答案:Whydoresultsvarybasedoncurlybraceplacement?(6个答案)WhataretherulesforJavaScript'sautomaticsemicoloninsertion(ASI)?(7个答案)关闭7年前。您可能知道,ECMAscript试图变得聪明,如果您没有显式编写分号,它会自动插入分号。简单的例子functionfoo(){varbar=5returnbar}仍将按预期工作。但是,如果您依赖于此,则有一些注意事项。如果我们像这样重写那个函数functionfoo(){varbar=5return{bar:bar

javascript - Webpack 在 require 语句中动态要求加载器

是否可以在require语句中使用带有显式加载器的动态require和require.context?我希望能够做这样的事情,但它对我不起作用:varreq=require.context('../somedir',false,/\.js$/);varimported=req('my-loader!'+someModulePath);//someModulePathdefinedabovesomewhere当我尝试这个时,我得到一个“找不到模块”的错误,这使得webpack似乎正在将字符串的my-loader!部分视为文件路径的开头,但是我希望my-loader!被识别为加载程序,如下

javascript - 无法修复 switch 语句中缩进 case 语句的 eslint 规则

这是我的sublimetext窗口的屏幕截图,显示了为switch/case语句抛出的eslint错误。我希望必须缩进4个空格,如代码所示。这里有4种不同的尝试,试图通过修改我的React应用程序中的.eslintrc文件来允许缩进4个空格。我在谷歌上搜索了一个解决方案,看到了添加switchCase和indentSwitchCase的建议,但我的.eslintrc规则都是-间隔的,而不是驼峰式,所以我添加了所有4条规则以努力从sublime文本中删除错误但没有运气......我做错了什么?!?!编辑:这是一个React/MERN应用程序,我使用sublimetext作为我的编辑器。让

javascript - 我是否需要 `else` 语句中的最后一个 `if...else if` 子句?

这个问题在这里已经有了答案:WhywouldJavascript`if...elseif`notendwithan`else`?(8个答案)关闭6年前。每个if...elseif我见过的示例包括一个最终的else子句:if(condition1){doA();}elseif(condition2){doB();}elseif(condition3){doC();}else{noConditionsMet();}alwaysDoThis();我知道这基本上是嵌套if...else的语法糖声明:if(condition1){doA();}else{if(condition2){doB();

javascript - 令人困惑的 JavaScript 语句 : "var x = new this();"

我以为我理解了JavaScript原型(prototype)对象的概念,以及[[proto]],直到我看到一些关于类继承的帖子。首先,“JavaScriptOOP-聪明的方式”在http://amix.dk/blog/viewEntry/19038查看实现部分:varparent=newthis('no_init');还有JohnResig的精彩博客上的“简单JavaScript继承”。varprototype=newthis();newthis();到底是什么意思?这个声明对我来说毫无意义,因为我的理解是this指向一个对象而不是构造函数。我还尝试在Firebug中测试语句来解决这个

javascript - 返回语句中的 ES6 解构

是否可以在返回对象的同时解构它。例如,要更改此代码:constmapStateToProps=({newItem})=>{const{id,name,price}=newItem;return{id,name,price};}像这样:constmapStateToProps=({newItem})=>{return{id,name,price}=newItem;} 最佳答案 不,这不可能。(免责声明:您的语法有效并且可以解构和返回,但它等同于({id,name,price}=newItem);//assignsglobalvaria

javascript - JS : Splitting a long string into strings with char limit while avoiding splitting words

我试图将一大段文本拆分成多个字符串,每个字符串148个字符,同时避免切断单词。我现在有这个,它正在拆分单词:varlength=shortData.new.length;if(length160&&length308&&length468&&length 最佳答案 你可以使用这个函数,只要传入你的字符串和长度,它就会返回数组,比如:varoutputString=splitter(shortData['new'],148);函数:functionsplitter(str,l){varstrs=[];while(str.length>

javascript - 在 if 语句中使用 undefined variable

此代码段导致JavaScript运行时错误:(foo未定义)if(foo){//...}我必须先定义foo,如下所示:varfoo=foo||null//orundefined,0,etc....只有这样我才能做:if(foo){//...}这是为什么呢?更新:这对我来说有点脑残:“当然你不能访问未分配的变量。”有趣的是,你可以对undefinedvariable执行typeof()。我要接受miccet的答案,因为我认为这是最优雅的解决方案。 最佳答案 我感觉到你在问,因为你知道javascript似乎在某些情况下(即没有运行时错

javascript - 在 ES6 模板文字中插入 if 语句

我有一个简单的ajax请求返回一些数据,然后插入到模板文字中。我想知道是否可以在模板中插入“if”语句?如果json对象有第5种颜色,本质上是添加一行代码。$.ajax({url:'http://localhost:8888/ColourCatchr%202/app/search.php'}).done(function(results){varres=jQuery.parseJSON(results);console.log(res);$.each(res,function(index,result){$('.palettes').append(`${result.name}${re