草庐IT

javascript - 避免 var _this = this;在编写 jQuery 事件处理程序时

这不是一个非常重要的问题,但我们开始吧..如何避免在jQuery事件处理程序中使用var_this=this?即我不喜欢这样做:var_this=this;$(el).click(function(event){//use_thistoaccesstheobjectand$(this)toaccessdomelement});下面2种方式都不理想$(el).click($.proxy(function(event){//lostaccesstothecorrectdomelement,i.e.event.targetisnotgoodenough(seehttp://jsfiddle.

javascript - 如何重新实现 'var that = this' 以使用 Object.prototype.bind() 保存范围引用?

在SecretsofJavascriptClosures,StuartLangridge提供了一段代码来演示闭包在.onclick回调中的常见用法,并解释如下:link.onclick=function(e){varnewa=document.createElement("a");varthat=this;document.body.appendChild(newa);newa.onclick=function(e){that.firstChild.nodeValue="reset";this.parentNode.removeChild(this);}}我最近偶然发现了KyleSim

javascript - 使用 html2canvas 截取 <body> 的屏幕截图并将图像存储为 JS var

我试图让我网站上的用户按下一个按钮来截取当前屏幕的屏幕截图(正文中的所有内容)。根据我的研究,html2canvas似乎是一种使这成为可能的资源。我的问题是文档没有提供示例代码,我很难掌握所涉及的步骤。http://html2canvas.hertzen.com/documentation.html以下SO问题(Howtouploadascreenshotusinghtml2canvas?)让我有点困惑。我现在只想知道如何获取图像。来自他的代码。$(window).ready(function(){('body').html2canvas();varcanvasRecord=newht

javascript - 'var' 声明的变量和 'this' 在 Javascript 中创建的属性有什么区别?

首先使用varfunctiontestCode(some){varsomething=some;}第二次使用这个functiontestCode2(some){this.something=some;} 最佳答案 在第一个函数中,something是一个private(局部)变量,这意味着它在函数外是完全不可访问的;而在第二个中,它是一个public实例变量。设置变量的上下文将取决于您调用函数的方式:>testCode2("foo");//thiswillrefertodocument.window>something"foo">>

javascript - browserify-shim 在 var 范围内时不导出隐式全局变量

根据browserify-shim文档,您可以通过在package.json中使用以下语法来指定browserify-shim需要从遗留模块公开哪些全局变量:{"browserify-shim":{"legacyModule":"myVar"}}我希望可以通过require('legacyModule')和window.myVar访问遗留模块。根据我的经验,如果我尝试填充的非commonjs模块使用window.myVar=x或仅使用myVar=x,则该模块会全局公开并且可按预期通过require()获得。但是,当遗留模块使用varmyVar=x时,这就是导致问题的原因,因为该模块只能

javascript - 在 "var new_function = function name(){};"中用 javascript 定义函数名有什么好处吗?

当我运行一个程序来更改我的javascript代码的某些部分时,它在将var声明为函数时出现错误,如下所示:varsome_function=functionname(args){//dostuff};代码本身有效,但我只是想知道是否可以删除我发现的所有函数的“名称”(因为它不会在分析我的javascript的其他问题中破坏它)或者它是否可以它可能有我看不到的任何用途。删除“名称”:varnew_function=function(){/*dostuff*/};注意:它第一次出现的原始文件在jquery-1.6.4.js中在:jQuerySub.fn.init=functioninit

javascript - let vs var 在 nodejs 和 chrome 中的性能

当我在chrome和nodejs中测试以下代码时,我得到以下信息:Chrome:forloopwithVAR:24.058msforloopwithLET:8.402msNodeJS:forloopwithVAR:4.329msforloopwithLET:8.727ms据我了解,由于block作用域,LET在chrome中更快。但是有人可以帮我理解为什么它在NodeJS中是相反的吗?还是我遗漏了什么?"usestrict";console.time("forloopwithVAR");for(vari=0;iPS:不确定这是否不是测试性能的理想方式。 最佳

javascript - 为什么要在这个 var 声明中将这个变量赋值给它自己?

我正在阅读BenCherry的“JavaScriptModulePattern:In-Depth”,他有一些我不太理解的示例代码。在Cross-FilePrivateState标题下,有一些示例代码如下:var_private=my._private=my._private||{}这看起来和写这样的东西没什么不同:var_private=my._private||{}这里发生了什么,这两个声明有何不同? 最佳答案 var_private=my._private=my._private||{}这一行的意思是如果my._private存

Javascript - 当标识符字符串存储在 var 中时访问对象成员

我有一个非常简单的问题(和初步答案),我只是想看看是否有更好的答案。当成员标识符存储在另一个变量中时,如何在javascript中访问对象成员?示例:state='sync';messages={'sync':'asdf','ready':'asdf','complete':'asdf'};可能性:1.message=eval('messages.'+state);将消息转换为散列(在原型(prototype)或jquery中——jquery不确定)并通过框架的方法访问还有哪些方法呢?有没有更干净的?在php中,它很简单$message=$messages->$sync。我确定这个问题

javascript - 是不是写: var arr=[]; than var arr=new Array();?比较好

这个问题在这里已经有了答案:What’sthedifferencebetween"Array()"and"[]"whiledeclaringaJavaScriptarray?(19个回答)Whatisthedifferencebetween`newObject()`andobjectliteralnotation?(12个答案)CreateanemptyobjectinJavaScriptwith{}ornewObject()?(10个答案)关闭5年前。是不是写的比较好vararr=[];thenvararr=newArray();varobj={};thenvarobj=newObj