草庐IT

Dockerfile调试和优化

全部标签

javascript - 在 RequireJs 中,如何指示优化器生成哈希输出文件名?

我这样运行优化器sudo/usr/local/bin/node/tmp/r.j/r.js-oname=mainout=test.jsbaseUrl=.用于测试现在,我如何告诉优化器将文件名输出为内容的哈希值(显然是为了设置maxexpires),然后在相关的require调用中重命名依赖项?一个示例情况是这样的require({baseUrl:'{{STATIC_URL}}js',paths:{jquery:'https://ajax.googleapis.com/ajax/libs/jquery/1.5.1/jquery.min',jqueryui:'http://ajax.goog

javascript - 从发布的 JavaScript 中删除 console.log 和其他调试代码的最佳实践?

我见过一些控制台包装器可以在带有控制台的浏览器中停止错误,而更高级的包装器可以在旧浏览器中启用日志记录。但我没有看到任何帮助打开和关闭调试代码的东西。目前我执行查找和替换以注释掉调试代码。一定有更好的方法吗?我正在使用Combres,它使用YUI来缩小JavaScript。我看过一些帖子提到使用双分号来标记要在缩小过程中删除的行。这是技巧还是好的做法? 最佳答案 也许您应该在console.log()周围有自己的包装器,并通过该包装器记录您的调试信息。这样,一旦部署到生产环境,您就可以用一个空函数替换该单个函数,这样控制台就不会充斥

javascript - .mousemove 和内存,我需要优化吗?

我在这里创建了一个简单的光测试演示:http://jsfiddle.net/CGr9d/当我使用Chrome开发工具记录内存使用情况时,我得到:http://cl.ly/LSDl,它基本上上升到某个点然后再次下降并重新开始,直到再次达到之前的高点。这正常吗?有什么方法可以优化我的代码以减少内存占用吗?这是我的mousemove函数:$('body').mousemove(function(e){//2000ishalftheimagewidth/height,ofcourseusedforcentering$('.light-circle').css({backgroundPositi

javascript - 调试显示模块模式 : functions not in scope until called?

如果我在Chrome开发者工具中运行这段代码:vartest=(function(){varpublicFunction,privateFunction1,privateFunction2;privateFunction1=functionprivateFunction1(){returntrue;};privateFunction2=functionprivateFunction2(){returntrue;};publicFunction=functionpublicFunction(){privateFunction1();debugger;};return{publicFunc

javascript - 如何调试 Chrome Javascript 中 GC 事件之间看似长时间的停顿

我一直在尝试优化一个Angular网站,但在某些路由之间切换时,我的页面响应出现大量延迟。显示的每个页面都不大,但其中包含相当数量的元素和合理数量的绑定(bind)。我已经用bindonce做了我能做的,所以我用Chrome查看了调试器,我发现我的大部分时间似乎都花在了GC上。奇怪的是,每个GC之间似乎存在巨大的差距,我正试图弄清楚这些差距到底是什么。我猜是在它实际删除项目时,小条是在进行标记和清除时,但我对分析JS的这种深度并不熟悉。我的大部分工作都是在C++/C#/Java中完成的。 最佳答案 在半秒内收集了超过20MB的垃圾。

javascript - ES6 尾调用优化是否涵盖生成器?

ES6对尾调用优化的支持是否涵盖生成器中的尾调用?假设我有这个>=0的整数生成器:varnums=function*(n){n=n||0;yieldn;yield*nums(n+1);};目前,在Chrome和Firefox中,它会为每个递归调用添加一个堆栈级别,最终会遇到“超出最大调用堆栈大小”错误。一旦ES6完全实现,这种情况还会发生吗?(我知道我可以迭代地编写上面的生成器而不会遇到错误。我只是好奇TCO是否会处理递归定义的生成器。) 最佳答案 当进行函数调用时,根据Functioncallevaluation部分,Lettai

javascript - browser.explorer() 与在 Protractor 中调试的旧方法

在Protractor5.0.0中,有一个新的browser.explore()方法已添加到API。和之前有什么不同browser.pause()或browser.debugger()或browser.enterRepl()?在Protractor中调试测试的首选方法是什么? 最佳答案 各有优缺点。browser.explore()是一个非常新的工具,它还具有使用我们在测试用例中使用的相同脚本调试测试的巨大优势,例如。element(by.cssContainingText('Username')).click();browser.

javascript:如何调试键盘事件

想象一个使用自定义键盘事件处理程序的Web应用程序,它可能会进行事件冒泡或事件捕获。有没有办法(例如Firefox/Firebug插件)调试每个击键/键盘事件,比如:显示事件类型和所有属性跟踪调用了哪个javascript方法在事件冒泡的情况下调用了进一步的方法澄清我的问题:我不知道存在哪些方法处理程序以及它们的定义位置-这正是我想要找出的。 最佳答案 您可以尝试使用Firebug+Eventbug可视化通风孔扩展名。有关不同浏览器中键盘事件的一般概述,请尝试以下操作:http://unixpapa.com/js/key.html

javascript交互式调试(相当于python的pdb.set_trace())

我正在使用一些javascript代码,我希望能够在函数调用的上下文中运行一个交互式控制台-也就是说,基本上正是python的importpdb;pdb.set_trace()完成。有什么办法吗?如果不是,那么最好的近似值是多少?我目前正在使用Chrome的控制台来处理一些事情,我基本上喜欢被放到函数调用的中间并使用Chrome的控制台来查看局部变量等。 最佳答案 设置断点,Chrome的检查器将允许您检查应用的状态。点击行号。将出现一个蓝色标记。当您点击该行时,执行将暂停。在您的代码中编写一个debugger语句。当您点击语句时,

javascript - 使用 node.js 调试服务器端

我脑子里有一个关于调试的紧迫问题,你看,当我编写Javascript客户端时,我可以转到Chrome的控制台并跟踪我的变量和对象等,以更好地了解我的代码发生了什么。我只是无法理解我们如何在服务器端(Nodejs)做同样的事情?假设我的前端向我的快速服务器提交了一个表单,我该如何检查req对象是否收到了它?我该去哪里检查变量和对象(调试)服务器端代码?我绝对不能在浏览器控制台上执行此操作,因为代码存在于服务器端并在服务器端执行,所以我无法通过浏览器控制台访问服务器端对象等。 最佳答案 您仍然可以执行console.log()。它会打印