草庐IT

这一次

全部标签

javascript - Angular 6 - 后退按钮按下触发器不止一次

我有以下代码使用Angular6检测后退按钮按下。import{Location}from'@angular/common';exportclassProductsComponentimplementsOnInit{constructor(privatelocation:Location){this.handleBackButtonPress();}handleBackButtonPress(){this.subscribed=true;this.location.subscribe(redirect=>{if(redirect.pop===true){alert('thisisaba

javascript - 如何一次执行几个 Ajax 请求

我不太确定这在JavaScript中是否可行,所以我想问一下。:)假设我们有100个请求要完成并且想加快速度。我想做的是:创建一个将启动前5个ajax调用的循环等到它们全部返回(成功-调用一个函数来更新dom/错误)-不确定如何,也许使用全局计数器?重复直到完成所有请求。考虑到浏览器JavaScript不支持线程,我们可以“利用”async功能来做到这一点吗?您认为它行得通吗,或者在JavaScript中这样做存在固有问题? 最佳答案 是的,我以前做过类似的事情。基本流程是:创建一个堆栈来存储您的作业(在本例中为请求)。首先执行3或

javascript - 是否可以输出我在上一次 session 中输入到控制台的所有代码?

是否可以输出我在上一次session中输入到控制台的所有代码?只有代码,没有结果。 最佳答案 在当前检查器中打开一个新的Web检查器(ctrl+shift+j,他们删除了递归检查元素),然后在新检查器中执行此操作:console.dir(WebInspector.consoleView.prompt._suggestBox._textPrompt._data)需要说明的是,您不会在页面的检查器中运行它。您在检查员的检查员中运行它。即:您的检查器也必须取消停靠,否则它只会转到当前检查器的控制台选项卡,而不是打开检查当前检查器的新检查器

JavaScript click() 方法仅在 Chrome 扩展程序中有效一次

我正在尝试在Chrome扩展程序中下载多个文件。以下代码创建一个指向文件的虚拟链接,然后触发下载文件的.click()事件。问题是只有第一个.click()事件触发下载。随后的.click()事件将被忽略。这里是ma​​nifest.json:{"name":"SimpleFileDownloader","version":"0.1","permissions":["contextMenus","http://*/"],"background":{"persistent":false,"scripts":["sample.js"]},"content_security_policy":

javascript - 调用同一个函数的两个 dom 事件如果同时发生,则应该只调用该函数一次

我有一个输入和一个按钮。当我从输入模糊并且输入发生变化时,应该调用price()函数。此外,当我单击按钮时,应该调用price()函数。问题在于,当用户修改输入值并单击按钮时,price()函数被调用了两次。我不希望发生这种情况。我尝试了老式的方法,在输入时将变量“inPriceFunction”设置为true,并在输入前检查它是否未设置。这没有用,因为两个事件(模糊和点击)是在同一时间执行的,if和变量集没有时间发生。我怎样才能避免这种情况?我尝试过的:testcalled=0;functionprice(){if(called==true){return;}else{called=

javascript - 为什么我的指令在使用 AngularJS 1.5 时第一次使用 ng-if 运行时没有进入动画?

http://codepen.io/anon/pen/MygQvb我使用的是Angular1.4.7,然后决定升级。在那之后,使用ng-if的指令上的所有动画都在它们应该发生的第一次停止工作。上面在Codepen上的例子说明了我的意思,如果你切换ng-if它不会在第一次工作,但后来它工作得很好。有一些类似的问题,但都没有解决我的问题,而且我在旧版本的Angular上也从未遇到过这个问题。真正的解决方案会很棒,但如果不可能,欢迎任何解决方法。 最佳答案 正如jjmontes所说,变通方法要求在template中声明指令的模板,而不是使

javascript - 为什么视频不播放,第一次播放时动态更改它不会播放

我正在使用videojs插件在点击每个视频时动态播放我的视频,但它没有播放我做错的地方。$(function(){$('.player-src').on('click',function(){//alert($(this).attr('data-src'));varvideosrc=$(this).attr('data-src');videojs('my_video_1',{ sources:[{ src:videosrc, type:'video/mp4' },{ src:videosrc, type:'video/webm' }] });});});

javascript - 如何强制小书签只运行一次?

我的小书签包含对插入到body中的“启动器”脚本的调用。在运行时,它会以类似的方式插入更多脚本(jQuery,实际应用程序)和CSS。书签javascript:(function(){varl=document.createElement('script');l.setAttribute('type','text/javascript');l.setAttribute('src','launcher.js');document.body.appendChild(l);})();Launcher.jsvars=document.createElement('script');s.setA

javascript - React 和 Axios 触发两次(一次未定义,一次成功)

按照ReactAJAX示例,我创建了一个JSX文件,其目的是获取和渲染电影。据我所知,我正在这里做所有事情。当我console.log渲染函数中的数据时,我得到2个结果:未定义对象(这是我需要的,所以这个是完美的)如何在我的渲染函数中不执行一些if/else逻辑的情况下过滤掉未定义的行?迭代结果当然会在第一次出现错误,这会使我的应用程序崩溃。处理此问题的最佳方法是什么?编辑:也许应用程序在Axios调用完成之前呈现,在这种情况下我被迫执行if/else语句?这是我的JSX文件:importReactfrom"react";importaxiosfrom"axios";exportdef

javascript - switchMap 操作只在第一次调用时运行?

我有一个Angular应用程序,它向Http服务发出请求并在另一个Http服务上调用switchMap。由于某种原因,switchMap中的请求仅在第一次调用父调用时运行。否则父请求会触发而switchMap不会,这里是代码:this._receivableService.newTenantDebitCredit(tenantCredit).take(1).switchMap(result=>//Refreshtheleasereceivablesbeforegivingresultthis._receivableService.getAll({refresh:true,where:{