草庐IT

php - 将对象克隆到 $this

全部标签

javascript - 如何在没有引用的情况下克隆数组

这个问题在这里已经有了答案:HowtoDeepcloneinjavascript(25个答案)关闭4年前。我正在尝试将数组克隆到一个新数组,并且我希望克隆的数组不引用原始副本我知道有splice和from方法,但是这些方法中的新数组都引用了原始数组例如letoriginal=[[1,2],[3,4]];letcloned=Array.from(original);//thiswillcopyeverythingfromoriginaloriginal[0][0]=-1;console.log(cloned[0][0]);//theclonedarrayelementvaluechang

javascript - 为什么 (function(){return this}).bind ('abc' )()== ='abc' 等于 false?

假设我有一个这样的函数:varf1=function(){returnthis;};console.log(f1.bind('abc')()==='abc');据我所知,f1.bind('abc')应该创建一个返回'abc'的新函数,所以我猜它的输出应该与console.log('abc'==='abc')这是真的,但现在输出是假的,我的猜测有什么问题吗? 最佳答案 在非严格模式下,原始值被包裹在对象中。所以,'abc'变成了newObject('abc')。在严格模式下,这不会发生。'usestrict';varf1=functi

javascript - 使用 this.state 在渲染中设置状态

我最近看到这种类型的react模式,其中使用this.state在渲染中设置状态:classShowMeextendsReact.Component{constructor(props){super(props);this.state={showButton:false,};}render(){if(this.props.show){this.state.showButton=true;//settingstateinrender!!}return(Showorhidebutton{this.state.showButton&&})}}这似乎是一种反模式。这会导致错误吗?不过它似乎工作

JavaScript 对象 : Why Doesn't This Work?

我写了下面的代码。它没有给我答案,而是输出NaN。我希望代码返回John和Mark的权重。请解释。'usescript';//DeclaringvariablesvarinfoJohn;varinfoMark;varbmiCalculator;varhigherBmi;bmiCalculator=function(height,mass){varcalculatedBmi;calculatedBmi=mass/(height*height);returncalculatedBmi;};infoJohn={name:'John',mass:85,height:110,bmi:bmiCal

javascript - <表单操作 ="javascript:alert(this);"> 什么是 "this"?

在尝试调试正在提交的内容时,我写了这个。是否可以提醒什么是正在提交?这里“this”指的是什么?我在警告框中收到对象,无法从中做出任何决定。:-) 最佳答案 在您的示例中,this是全局window对象。自己试试:结果为"function"(即全局函数)。或者尝试:结果为undefined(即它不指向表单元素)*。属性中"this"的值只会是以下两种情况之一:全局窗口对象元素本身唯一一次this指向元素本身是在intrinsiceventattribute中使用它时(以“on”为前缀的那些,例如“onclick”、“onload”等

javascript - 变量范围 : this. remove 不是函数

this.remove()不是函数。怎么会?varvehicle=function(){return{init:function(){jQuery('.vehicle-year-profile.options.delete').bind('click',function(e){e.preventDefault();this.remove();});},remove:function(){alert('test');}}}();jQuery().ready(vehicle.init);抱歉造成混淆。我正在尝试调用我自己的“删除”功能。这只是一个在我的页面上管理车辆的类。这是它的开始,它将

javascript - 如何在 JS 的 setTimeout 中调用 this.function?

我有以下JS:functionTrackTime(){this.CountBack=function(secs){setTimeout(function(){this.CountBack(secs)},SetTimeOutPeriod);}}我已经用闭包(见上文)和其他十几种方法尝试过这个。我似乎无法在任何浏览器中使用它。setTimeout函数在未在“类”函数中调用时工作正常。有人可以帮我吗? 最佳答案 发生这种情况是因为执行函数时“this”的范围发生了变化。试试这个技巧..functionTrackTime(){this.Co

javascript - 为什么 toString() 和 this.toString() 在 Chrome 的控制台中产生不同的结果?

现在这根本没有任何实际意义,但我对我偶然发现的这个小怪癖很好奇。基本上,在Chrome的开发者控制台中,这toString()返回[objectObject],而这个this.toString()返回[objectDOMWindow]。据我所知,这只发生在控制台,可以看出onthisjsFiddle.有人在##javascript上找到了thislink解释函数的来源。但是,它没有解释在控制台内部或外部使用时行为中存在的差异。那么为什么toString()和this.toString()在Chrome的控制台中产生不同的结果? 最佳答案

JavaScript "this"引用了错误的对象

这个问题在这里已经有了答案:Howtoaccessthecorrect`this`insideacallback(13个答案)关闭6年前。好吧,this并没有真正引用错误的对象,但我不知道如何引用正确的对象。functionsomeObj(){this.someMethod1=function(){varelementBtn=document.getElementById('myBtn');elementBtn.onclick=function(){this.someMethod2();//Iwantthis.someMethod2()tobecalled//...butittries

javascript - “var” 变量、"this"变量和 "global"变量 - 在 JavaScript 构造函数中

在我上一个问题之后,这个问题对我来说更准确:例子:functionFoo(){this.bla=1;varblabla=10;blablabla=100;this.getblabla=function(){returnblabla;//exposesblablaoutside}}foo=newFoo();我现在的理解:this.bla=1;//willbecomeanattributeofeveryinstanceofFOO.varblabla=10;//willbecomealocalvariableofFoo(will**not**becomeanattributeofeveryi