草庐IT

random_number_array

全部标签

javascript - array.forEach 比 native 迭代运行得更快?如何?

http://jsperf.com/testing-foreach-vs-for-loop据我了解,测试用例2的运行速度应该比测试用例1慢——我想看看慢了多少。想象一下当我看到它运行得更快时我的惊讶!这是怎么回事?幕后优化?还是.forEach更干净更快?在WindowsServer2008R2/764位上测试Chrome18.0.1025.14232位 最佳答案 for循环缺少许多迭代优化,例如:缓存数组长度向后迭代使用++counter代替counter++这些是我听说过和用过的,相信还有更多。如果没记错的话,向后迭代while

javascript - typescript : check a string for number

我是网络开发的新手,在我的函数中想检查给定的字符串值是否为数字。如果字符串不是有效数字,我想返回null。以下适用于所有情况,除非字符串为“0”,在这种情况下它返回null。parseInt(columnSortSettings[0])||null;如何防止这种情况发生。显然parseInt不会将0视为整数! 最佳答案 因为0是假的,所以你可以使用isNaN()在这种情况下varres=parseInt(columnSortSettings[0],10);returnisNaN(res)?null:res;

Javascript 继承 : Parent's array variable retains value

我在这里尝试在JavaScript中使用继承,我发现Parent类中的数组值被Child类继承时出现问题。下面的代码是正常的继承:varParent=function(){this.list=[];};varChild=function(){};Child.prototype=newParent;Child.prototype.constructor=Child;varobj1=newChild;obj1.list.push("hello");console.log(obj1.list);//prints["hello"];当我将新的Child对象(继承包含名为list的数组变量的Pa

javascript - Array.prototype.slice 奇怪的行为

考虑这段代码,每行末尾都有控制台输出:functionwhatever(){console.log(arguments)//{'0':1,'1':2,'2':3,'3':4,'4':5}console.log(Array.prototype.slice.call(arguments))//[1,2,3,4,5]console.log(Array.prototype.slice.call({'0':1,'1':2,'2':3,'3':4,'4':5}))//[]}whatever(1,2,3,4,5)为什么第三个console.log输出一个空数组? 最佳答案

javascript - 使用多个小数点对 'numbers' 进行排序

我有一堆有多个小数点的“数字”(所以它们实际上是字符串)。但是,我想对它们进行排序,就好像它们是数字一样。1.1.110.2.32.6.721.10.43.10.124.11.54.1.166.4.23我希望他们按第一组数字(第一个小数点之前)排序,然后按第二组数字排序,然后按第三组数字排序(可能会持续第四组或更多)。他们应该按以下顺序进行:1.1.12.6.73.10.124.1.164.11.56.4.2310.2.321.10.4使用JS执行此操作的最佳方法是什么?我在想我可能需要将每个数字分解成一个数组,但也许有更好的方法。想法? 最佳答案

javascript - Array.filter 无法正常工作

我有一个数组,我想从中删除一条记录我已经使用了Array.filter()但它返回的是相同的数组。我的代码:varurl=window.location.pathname,orderId=url.split('/').slice(-2)[0];varCart=JSON.parse(localStorage.getItem('Cart'));newCart=Cart.filter(function(item){if(parseInt(item.orderId)==parseInt(orderId)){return{};}else{returnitem;}});localStorage.s

javascript - JavaScript 中的 "new Number(...)"和 "Number(...)"有什么区别?

在Javascript中,reliablewaystoconvertastringtoanumber之一是Number构造函数:varx=Number('09');//9,becauseitdefaultstodecimal灵感来自thisquestion,我开始想知道——上面和之间有什么区别:varx=newNumber('09');Number当然看起来更好,但它似乎对构造函数的使用有点不合适。在没有新的情况下使用它有任何副作用或有什么不同吗?如果没有区别,为什么不呢?new的目的是什么? 最佳答案 在第一种情况下,您使用的是N

javascript - Prototype 在这个 Array slice 调用中,为什么?

我正在阅读JS函数的arguments变量的MDN页面:https://developer.mozilla.org/en/JavaScript/Reference/Functions_and_function_scope/arguments我知道arguments不是数组,所以这行不通:vara=arguments.slice();MDN上的解决方案是这样做:varargs=Array.prototype.slice.call(arguments);为什么使用Array.prototype而不仅仅是Array.slice.call(arguments)?在这里使用原型(prototyp

javascript - 在 IE 中将函数添加到 Array.prototype 会导致它作为元素被插入每个数组

我在项目的开头将以下polyfill添加到Array:if(!Array.prototype.find){Array.prototype.find=function(predicate){if(this===null){thrownewTypeError('Array.prototype.findcalledonnullorundefined');}if(typeofpredicate!=='function'){thrownewTypeError('predicatemustbeafunction');}varlist=Object(this);varlength=list.leng

javascript - 你能用用户定义的对象伪造 Array.isArray() 吗?

我很好奇是否有任何方法可以用用户定义的对象伪造出Array.isArray()。摘自《JavaScript模式》一书:Array.isArray([]);//true//tryingtofoolthecheck//withanarray-likeobjectArray.isArray({length:1,"0":1,slice:function(){}});//false那个对象显然失败了,但是还有其他方法吗?这纯粹是出于好奇,并不是因为我认为您可以在常规客户端代码中搞砸.isArray()(尽管知道如果可以的话显然会很棒!)。 最佳答案