草庐IT

object_to_array

全部标签

设置原型(prototype)时Javascript继承: calling Object.创建

我正在学习面向对象的Javascript的某些方面。我遇到了这个片段varPerson=function(firstName,lastName){this.lastName=lastName;this.firstName=firstName;};Object.defineProperties(Person.prototype,{sayHi:{value:function(){return"Himynameis"+this.firstName;}},fullName:{get:function(){returnthis.firstName+""+this.lastName;}}});va

javascript-objects - 如何在javascript的函数钩子(Hook)中访问全局变量?

我想在下面的钩子(Hook)函数中使用全局变量'x'。varx=10;//globalvariablevaroldA=a;a=functiona(param){alert(x);//showingerror:xisundefinedreturnoldA(param);}如何解决错误? 最佳答案 您的代码对我来说工作正常,但您可能希望通过使用window.x将x显式解析为全局变量。如果不在浏览器环境中,或者全局对象未被称为window的环境中,请尝试:(window||root||global||GLOBAL||this||self|

javascript - Object.create(null) 的用例?

如果您使用varobj={};创建一个常规的javascript对象,它将具有对象原型(prototype)。使用varobj=newMyClass();创建的对象也是如此在引入Object.create之前,没有办法解决这个问题。然而,现在可以使用varobj=Object.create(null);创建一个没有原型(prototype)的对象(相应的null作为其原型(prototype))。为什么这很重要?它带来了哪些优势?有任何现实世界的用例吗? 最佳答案 它是一个完全空的对象(没有从任何.prototype继承,包括Obj

javascript - 为什么 Float32Array.length 的值总是 3?

我正在阅读theMozillaDeveloperNetworkdocsonFloat32Arrays当我遇到的时候Float32Array.lengthLengthpropertywhosevalueis3....为什么总是3?我还注意到同名的原型(prototype)属性覆盖了它。 最佳答案 Float32Array实际上是一个函数。你可以这样检查console.assert(typeofFloat32Array==='function');那个函数接受三个参数。引用同一文档中的签名,Float32Array(buffer[,by

javascript - 为什么 `typeof this` 返回 "object"?

varf=function(o){returnthis+":"+o+"::"+(typeofthis)+":"+(typeofo)};f.call("2","2");//"2:2::object:string"varf=function(o){returnthis+":"+(typeofthis)+":"+(typeofo);};varx=[1,/foo/,"bar",function(){},true,[],{}];for(vari=0;i我在Chrome、Firefox和Safari中看到相同的结果,所以我假设它符合thespec,但为什么?这在规范中的何处定义?为什么不是函数?

javascript - IE8上 "typeerror object doesn' t支持这个属性或方法的一般解决方案是什么?

我看到了几个关于这个问题的具体问题-在IE8中获取typeerrorobjectdoesn'tsupportthispropertyormethod,每个问题都有其具体的答案。假设我有一个包含大量代码的大型网站......我不知道是什么特定片段导致了这个错误。有没有通用的调试方法?我试过使用IE开发人员工具,它不会因错误而中断。这是由不正确的javascript语法引起的吗?我应该尝试像jslint这样的东西吗?识别和处理此问题的正确、通用方法是什么? 最佳答案 好吧,所以我转向了古老的解决方案并开始从我的项目中删除大量代码,直到问

javascript - react .js : Is it possible to namespace child components while still using JSX to refer to them?

假设我有一个名为ImageGrid的组件定义如下:window.ImageGrid=React.createClass({render:function(){return();}});如您所见,它包含一个名为ImageGridItem的子React组件。.其定义如下。window.ImageGridItem=React.createClass({render:function(){return(something);}});只要两者都是window的直接属性,这就可以正常工作.但这有点可怕,所以我想将我所有的react组件分组到window.myComponents的命名空间下。例如。

javascript - 有人可以解释这个 Array.prototype.find() polyfill 吗?

在此MDN页面上[https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find]有这个polyfill:if(!Array.prototype.find){Object.defineProperty(Array.prototype,'find',{enumerable:false,configurable:true,writable:true,value:function(predicate){if(this==null){thrownewTypeError('Ar

javascript - 依赖 Content-Type : text/plain to mitigate malicious javascript execution in response? 是否安全

我们有一个返回的web应用程序HTTP/1.1400BadRequest...Content-Type:text/plain;charset=UTF-8Content-Length:57Date:Tue,14Apr201519:24:54GMTConnection:closeInvalidprojectareaitemidalert(1086)据我了解,依靠Content-Type:text/plain;charset=UTF-8作为防御来阻止javascript执行是不够的。相反,应该对输出进行编码,并且应该对输入进行输入验证并丢弃垃圾。我正在寻找的是关于处理具有javascript

javascript - vscode : [ts] Experimental support for decorators is a feature that is subject to change

我得到“[ts]对装饰器的实验性支持是一项功能,在未来的版本中可能会发生变化。设置'experimentalDecorators'选项以删除此警告。”我是Angular的新手,我不知道如何解决它。我的tsconfig.json文件:{"compilerOptions":{"allowSyntheticDefaultImports":true,"declaration":false,"emitDecoratorMetadata":true,"experimentalDecorators":true,"lib":["dom","es2015"],"module":"es2015","mod