草庐IT

MySQL算术运算

全部标签

javascript - React JS/Typescript 中的空合并运算符

这个问题在这里已经有了答案:Safenavigationoperator(?.)or(!.)andnullpropertypaths(7个答案)ReplacementofElvisOperatorofAngular2inTypescript(3个答案)关闭4年前。我们在.NET中有Null合并运算符,我们可以按如下方式使用stringpostal_code=address?.postal_code;我们可以在ReactJS中做同样的事情吗?我发现我们可以用&&运算符做什么在address.ts文件中stringpostal_code=address&&address.postal_co

javascript - 为什么表达式 new Date().getTime() 中的运算符严格按照从左到右的顺序应用?

以下表达式似乎按预期工作并返回当前时间戳。newDate().getTime()但是我不明白为什么运算符在这里严格按照从左到右的顺序应用。MDN表示成员(.)运算符的优先级高于new。这意味着.必须在new之前应用。所以表达式应该被评估为:new(Date().getTime())但实际上是这样评价的:(newDate()).getTime()我想一定是我忽略了什么,但我不明白是什么。注意:我实际上并没有使用这个表达式(我更喜欢Date.now()方法)。这只是我的好奇心。 最佳答案 MDN优先级表并不完全正确;new运算符和属性访

javascript - 当一个是 bool 值时,为什么 JavaScript 在 == 运算符比较中将原始值转换为数字的基本原理?

我知道规则:Ifthetwooperandsarenotofthesametype,JavaScriptconvertstheoperandsthenappliesstrictcomparison.Ifeitheroperandisanumberoraboolean,theoperandsareconvertedtonumbersifpossible;elseifeitheroperandisastring,theotheroperandisconvertedtoastringifpossible.所以,if("true")通过但if("true"==true)失败,因为它的句柄类似于

javascript - "in"运算符或 obj.hasOwnProperty(prop) 的 Big O 表示法的效率是多少

Mozilla的网站清楚地描述了hasOwnProperty()。和in运营商。但是,它没有提供有关其效率的任何实现细节。我怀疑它们会是O(1)(常数时间),但我希望看到任何可能存在的引用或测试。 最佳答案 将我的评论变成答案。hasOwnProperty()应该O(1),因为它是一个键查找,但它是特定于实现的。in肯定会更复杂(尽管应该与hasOwnProperty()相同,如果属性存在于该对象上),因为它沿着原型(prototype)链上升,寻找那个属性(property)。这就是为什么通常建议在使用for(in)遍历对象属性时

javascript - 为什么我们不能在没有 new 运算符的情况下调用 Date() 类的方法

这个问题在这里已经有了答案:DifferencebetweenDate(dateString)andnewDate(dateString)(10个答案)关闭8年前。假设我这样定义一个变量vartoday=Date();console.log(today.getMonth());//ThrowError而像Error类这样的其他类在没有new运算符的情况下调用它们的方法。functionfactorial(x){if(x包装器对象(数字、bool值、字符串)也可以在没有new运算符的情况下调用它们的方法。那么,这是唯一一个在调用它们的方法之前需要new运算符或任何对象创建技术的类吗。编辑

javascript - 将不同的 this 作用域绑定(bind)到 ES6 => 函数运算符

在尝试使用ES6提供的=>特性继承上下文后,我注意到this上下文永远无法更改。示例:varotherContext={a:2};functionfoo(){this.a=1;this.bar=()=>this.a;}varinstance=newfoo;instance.bar();//returns1instance.bar.bind(otherContext)();//returns1没有=>运算符并使用function关键字:functionfoo(){this.a=1;this.bar=function(){returnthis.a;}}varinstance=newfoo;

javascript - 如何使用 || 的箭头函数运算符(operator)

使用Babel,我可以看到callback=()=>{};编译为callback=functioncallback(){};这是我所期望的。但是,当我尝试将它与||一起使用时出现错误callback=callback||()=>{}我希望它等同于callback=callback||function(){};为什么这是一个错误?另外,对于这种熟悉的语法,是否有更正确的ES6版本? 最佳答案 失败是因为语法无效。使用以下命令使其工作:callback=callback||(()=>{})如果您不以这种方式包装它,它将被解释为您键入以下

javascript - 获取对运算符后面的 JavaScript 函数对象的引用

这是一个lisp过程,它简单地将“a”加到“b”的绝对值上:(define(a-plus-abs-bab)((if(>b0)+-)ab))我认为这很漂亮,我正在尝试找到用JavaScript编写它的最佳方式。但是我的JavaScript代码并不漂亮:varplus=function(a,b){returna+b;};varminus=function(a,b){returna-b;};varaPlusAbsB=function(a,b){return(b>0?plus:minus)(a,b);}主要问题是我不能像使用lisp那样使用+和-符号作为对它们真正表示的函数的引用。谁能想出一种

javascript - 如果存在则使用值,否则使用 or 运算符分配默认值

我在一本书中找到了这个例子://Create_callbacksobject,unlessitalreadyexistsvarcalls=this._callbacks||(this._callbacks={});我简化了它,这样我就不必使用特殊的对象范围了:vara=b||(b="Hello!");当b被定义时,它就起作用了。当b未定义时,它不起作用并抛出ReferenceError。ReferenceError:bisnotdefined我做错了什么吗?谢谢! 最佳答案 当执行像this._callback这样的属性查找时,如果

javascript - 如何在不使用 eval 或构造函数的情况下用 JavaScript 编写算术表达式解析器?

给定一个字符串:varstr1="25*5+5*7";如果不使用eval或JavaScript中的构造函数,我将如何编写一个名为“output”的函数来接收字符串并输出字符串的算术值,在这个案例是160? 最佳答案 这是递归解析后的完整优先表达式求值器我在对OP问题的评论中链接到的想法。为此,我首先为要处理的表达式编写了一个简单的BNF语法:sum=product|sum"+"product|sum"-"product;product=term|product"*"term|product"/"term;term="-"term|"