草庐IT

异步处理

全部标签

javascript - 是否使用 ".click()"异步触发事件监听器?

我有以下代码(我的HTML中有一个):(function(){'usestrict';document.getElementById(7).addEventListener("click",function(){console.log('clicked');})console.log('before');document.getElementById(7).click();console.log('after')}());当它在Firefox41控制台中运行时,我会预料到之前之后点击因为代码会同步运行,然后在完成脚本后响应事件队列中的点击事件。相反,我得到了之前点击在之后这表明事件正在

javascript - ES6 异步生成器结果

ES6有generatorsthatreturniterators:function*range(n){for(leti=0;i有一个关于返回Promises的异步函数的提议:asyncfunctionf(x){lety=awaitg(x);returny*y;}f(2).then(y=>{console.log(y);});那么如果我将两者结合起来会发生什么,就像这样:asyncfunction*ag(n){for(leti=0;i它返回什么?是Promise>?Iterator>?还有别的吗?我该如何食用它?我想应该有一个相应的for循环,什么将异步迭代其结果,例如:for(awa

javascript - 使用 promise 异步递归

所以我试图将我的代码转移到“Promise世界”,并且在许多地方当我不得不使用异步功能“循环”时-我只是以这种方式使用递归functiondoRecursion(idx,callback){if(idx现在我正在尝试改变Promise世界,但我很困varPromise=require('bluebird')functiondoRecursion(idx){returnnewPromise(function(resolve){if(idx谢谢。 最佳答案 我会选择Promise.all方法。它所做的是等待数组中的所有promise都已

javascript - 使用 moment.js 防止 DST 偏移以处理重复发生的事件

我正在构建的系统有一个事件组件,其中一部分是创建重复事件的能力。在我的数据库中,我以UTC格式存储所有事件。当一个重复事件显示在用户的日历上时,它应该总是显示在“墙上时间”中。因此,例如,如果我在每周三下午1:00创建一个重复事件,无论夏令时如何变化,它都应该始终在下午1:00。我遇到的问题是,每当我尝试使用Moment.js设置此日期的格式时,Moment始终会考虑DST转换并相应地更新事件。以我之前的示例为例,在2016年,DST类次发生在3月13日,因此如果我的约会是在2016年2月预订的,那么3月13日之前的每个约会都会正确输出为1:00PM。3月13日之后,应用夏令时转变,我

javascript - 如何从 Firefox 的上传处理程序中过滤掉目录?

问题我有以下代码片段用于在文件拖放上传期间获取文件信息:varfiles=event.dataTransfer.files;for(vari=0;iName:${file.name}Size:${file.size}bytesType:${file.type}ModifiedDate:${file.lastModifiedDate}`;});}我做了研究,发现Firefox不支持目录上传,但允许客户端将它们拖放到拖放区。问题如何从Firefox的上传处理程序中过滤掉目录?更新您可以在这里找到工作示例:https://jsfiddle.net/gevorgha/exs3ta25/请考虑我

javascript - 在 Firebase 中处理关联帐户

我正在遵循Firebase关于社交登录的说明。下面是我正在使用的示例,从登录身份验证的Angular来看,它一切正常。但是,我有独立工作的Google和Facebook登录。我现在希望能够做的是链接帐户。实际上,您可以在下面看到这可能发生的情况(请参阅评论):Ifyouareusingmultipleauthprovidersonyourappyoushouldhandlelinkingtheuser'saccountshere.我已经尝试了很多我认为应该放在这里的变体,但都无济于事。任何人都可以就他们认为应该放在这里的内容指导我吗?谢谢!functioninitFBApp(){//R

javascript - 使用 chrome.tabs.executeScript 执行异步函数

我有一个功能,我想使用chrome.tabs.executeScript在页面中执行,从浏览器操作弹出窗口运行。权限设置正确,并且可以正常使用同步回调:chrome.tabs.executeScript(tab.id,{code:`(function(){//Dolotsofthingsreturntrue;})()`},r=>console.log(r[0]));//Logstrue问题是我要调用的函数要经过几个回调,所以我想使用async和await:chrome.tabs.executeScript(tab.id,{code:`(asyncfunction(){//Dolotso

javascript - 如何使用 TypeScript 将拖动事件处理程序附加到 React 组件

我正在使用TypeScript(2.4.2)首次涉足React(15.6.1),我正在尝试创建一个组件来表示可拖动的JSON字段。这是我的组件代码:import*asReactfrom"react";interfaceJsonFieldProps{name:string;type:string;indent:number;}exportclassJsonFieldextendsReact.Component{marginStyle={'text-indent':`${this.props.indent*15}px`};render(){return{this.props.name}:{

javascript - 动态插入字符串上的 Vue 事件处理程序不起作用

这是我的代码:ClickMetoreplacedivcontentsexportdefault{data(){return{data:"Iwillbereplacedonceyouclickonbutton"}},methods:{clickMe(){alert("worked");},replace(){this.data="Whydoesclickmenotwork?ItisloadedfromserverviaajaxClickMe";}}};在这里,如果我点击ClickMetoreplacedivcontents,内容会被替换,但事件处理程序clickMe不会触发。该数据将来自

javascript - 使用 XMLHttpRequest 和通用处理程序通过 FTP 下载 PDF 文件

我正在尝试使用JqueryAjax请求从FTP服务器下载PDF文件。我提到了http://www.dave-bond.com/blog/2010/01/JQuery-ajax-progress-HMTL5/.我的Jqueryajax调用如下所示$.ajax({xhr:function(){varxhr=newwindow.XMLHttpRequest();//Downloadprogressxhr.addEventListener("progress",function(evt){console.log("Event:"+evt.lengthComputable);if(evt.len