草庐IT

for-in-loop

全部标签

javascript - react 路由器 : access history in rendered Route component

我知道有很多关于此的问题,但我似乎无法让它工作:我需要从通过路由呈现的子组件访问“历史记录”。(它从redux容器接收Prop)。我需要将历史对象传递给在每个路由中呈现的组件,这样我就可以this.props.history.push('/route')在子组件中。这个应用程序以前不太动态,所以每个Route都用component={someComponent}硬编码;但我发现在动态执行路由时,您需要使用render={()=>}.从component={}更改路线后至render={()=>...}我在子组件中丢失了历史记录。我的代码是这样的:importReact,{Compone

javascript - Cloud Functions for Firebase 在 CORS 预检请求上触发功能

我有一个云功能,可以验证来自客户端表单提交的输入。我正在为Firebase使用CloudFunctionshttpstriggers与corsexpressmiddleware.Firebase函数constfunctions=require('firebase-functions');constexpress=require('express');constcors=require('cors')({origin:true});constvalidateImageForm=require('./library/validate-image-form');exports.apiVali

javascript - Firefox 权限 : 'name' member of PermissionDescriptor 'camera' is not a valid value for enumeration PermissionName

我正在制作一个网络应用,需要使用权限查询来检查是否已授予用户相机访问权限。我试过代码:navigator.permissions.query({name:'camera'}).then(function(result){console.log(result);});它在GoogleChrome70上运行良好,但在firefox上出现错误:TypeError:PermissionDescriptor“camera”的“name”成员不是枚举PermissionName的有效值。我一直在寻找这个问题,但没有任何帮助。有人能帮帮我吗?谢谢, 最佳答案

javascript - 最好的办法 :not in jQuery?

我在jQuery中有一个菜单,当你点击一个链接时它会打开,但我想要它所以当你点击其他地方时,其他任何不是菜单的地方,它就会隐藏起来。目前我正在绑定(bind)一个点击事件$(':not(#the_menu)')但这似乎是我将点击事件绑定(bind)到整个减去菜单,有没有更有效的方法来做这样的事情? 最佳答案 最好的方法是使用冒泡捕获,如下所示:$(document).click(function(){//closemenu})$("#the_menu").click(function(e){e.stopPropagation();}

javascript - if with a continue 是一个很好的模式来防止在 Javascript 中迭代属性时过度嵌套吗?

我通常使用这种模式来迭代对象属性:for(varpropertyinobject){if(object.hasOwnProperty(property)){...}}我不喜欢这种过度的缩进,最近有人向我指出我可以通过这样做来摆脱它:for(varpropertyinobject){if(!object.hasOwnProperty(property)){continue;}...}我喜欢这个,因为它没有引入额外的缩进级别。这种模式可以吗,或者有更好的方法吗? 最佳答案 我个人比较喜欢:for(varpropertyinobject)

javascript - XMLHttpRequest : Browser support for sendAsBinary?

Firefox是唯一支持sendAsBinary方法的吗? 最佳答案 目前,我相信只有FF3+支持这个,尽管有一个workaround适用于Chrome。 关于javascript-XMLHttpRequest:BrowsersupportforsendAsBinary?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4236153/

javascript - JS : Recognize dot or delete in keypress

如果用户按下点(在标准键盘或数字block上),我想执行一些代码。但是如果我把它接过来Keycode(110),这就和删除按钮一样了。我如何识别它们?感谢您的帮助! 最佳答案 删除键(通常在箭头上方)为46,数字小数点为110,键盘周期为190。这是一个非常好的页面,可以了解什么是键码:http://www.cambiaresearch.com/c4/702b8cd1-e5b0-42e6-83ac-25f0306e3e25/Javascript-Char-Codes-Key-Codes.aspx如果这不能回答您的问题,请重新措辞,因

javascript - d3 + 主干 : updating elements for which data has changed

我将d3与Backbone.js模型一起使用。当模型属性发生变化时,将触发一个事件,并用hasChanged()标志标记模型,并返回一个changedAttributes()散列。我了解如何使用d3的enter()和exit()来处理已创建或删除的模型。我无法弄清楚的是如何根据模型属性的变化修改相应的DOM元素。我可以使用Backbone助手来确定要修改的内容,但是d3的下一步是什么? 最佳答案 我在d3邮件列表上得到了一些有用的回复:http://groups.google.com/group/d3-js/browse_threa

javascript - 前后交替执行javascsript for循环

更新如下我正在尝试做的是以block为单位遍历数组,从一个block到另一个block交替迭代的方向。使困惑?我也是。例如,如果我想遍历一个包含25个元素的数组,但我想按以下顺序进行:0、1、2、3、4、9、8、7、6、5、10,11,12,13,14,19,18,17,16,15,20,21,22,23,24,最有效的方法是什么?我正在寻找可扩展的东西,因为我现在使用的数组实际上是225个元素,我想以15个元素block的形式遍历它,但这在某些时候可能会改变。到目前为止,我发现唯一可行的方法是将迭代顺序硬连接到第二个数组,然后以正常方式迭代它以获取原始数组的索引。但这很糟糕。任何帮助

javascript - jQuery 选择器 : all but n first in a row

所以我有一个这样的sibling列表;(注意b不是a的child,它们是所有sibling。缩进是为了强调。)在jQuery中,我需要选择每个b,放弃连续的前n个元素。没有特定类型/类的元素会打破连胜,也没有任何可靠数量的b在连胜中,或非b元素之间。如果我使用选择器添加一个类selected,并且假设n=2,那么我的DOM将如下所示;换句话说,选择除b之外的所有b元素以外的所有n元素,或开头。我试过:nth-child(n+3),但这似乎只是考虑了所有b,尽管a会破坏它们。我也试过摆弄.nextUntil()和.filter(),但必须有比我更好的人才能破解这个问题。想法?