jjzjj

javascript - 将 Javascript getter 作为参数传递

我有一个ecma6/es2015类,它的getter定义如下:getfoo(){returnthis._foo;}我希望能够做的是将该函数作为参数传递。像这样打电话:someFunction(myClass.foo);将简单地调用该函数。有没有一种干净的方法可以在不调用它的情况下传递方法,然后在传递它的过程中调用? 最佳答案 我假设您必须将它包装到一个匿名函数中以防止它被执行:someFunction(()=>myClass.foo);或者,你可以获得getter函数本身,但是它的可读性不如上面的:someFunction(Obje

javascript - 近期 Chrome/V8 版本中的对象描述符 getter/setter 性能

给定varobj={};var_a=1;obj._a=1;obj.aGetter=function(){return_a;}obj.aSetter=function(val){_a=val;}Object.defineProperty(obj,'a',{enumerable:true,get:function(){return_a;},set:function(val){_a=val;}});使用getter/setter函数obj.aSetter(2);obj.aGetter();与直接属性访问相比,Chrome/V8性能会有所下降(~3倍):obj._a=2;obj._a;这是可以

javascript - 直接访问 vuex 状态属性(没有 getter)是不好的做法,为什么?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭5年前。Improvethisquestion如果这是我的store.js文件:conststate={count:0,loggedIn:false}constmutations={UP_COUNT(state){state++;}}constactions={upCount({commit}){commit('UP_COUNT');}}假设要从我的一个Vue组件增加状态count,我将调用一个Action,然后提交一个突变:this

javascript - vuex:未知 setter/getter :用户

我正在试验vuex,我一直在寻找组织我的vuex文件的最佳方式,我完成了这样的事情:/src/store/user/state.js:exportdefault{state:{user:null}}/src/store/user/getters.js:exportdefault{getters:{user(state){returnstate.user}}}/src/store/user/mutations.js:exportdefault{mutations:{'SET_USER'(state,user){state.user=user}}}/src/store/user/actio

javascript - 未捕获的类型错误 : Cannot set property style of#<HTMLElement> which has only a getter

以下代码在Chrome、Safari中失败,在Firefox中运行良好"usestrict";document.body.style="background-color:green;";backgroundshouldbegreen删除“usingstrict”,它起作用了。这是Chrome和Safari中的错误还是Firefox中的错误?MDNsayssettingthestyleisvalid. 最佳答案 问题并非所有浏览器都支持将包含CSS声明block文本表示的字符串分配给style属性。element.style=styl

javascript - 使用相同的 getter 和 setter 创建多个属性

最近我一直在编写一些涉及使用getters的JavaScript程序。和setters.我阅读了这两种方法的MDN文档,但在尝试使用它们时感到困惑。我想创建一系列具有相同getter和setter的相似属性,但我不想为每个属性重写每个setter和getter。实现综上所述,我尝试执行以下代码:vardefaultProperty={set:function(val){this.value=val-1;//Justanexample},get:function(){returnthis.value+1;//Justanexample}};varmyObj={};Object.defin

javascript - 懒惰的 setter/getter 在类里面不起作用

classa{getb(){deletethis.b;returnthis.b=1;}}varc={getb(){deletethis.b;returnthis.b=1;}}console.log(c.b);//worksasexpectedconsole.log((newa()).b);//throwserror上面的代码应该可以正常工作,但最后一行抛出错误。UncaughtTypeError:Cannotsetpropertybof#whichhasonlyagetter(…)很明显,getter并没有在类中被删除,而它在对象中工作正常。我正在使用最新的稳定版chrome。Lazy

javascript - Vue.js : "TypeError: Cannot set property props of#<Object> which has only a getter"

我正在尝试实例化一个Vue组件,但出现错误:[Vuewarn]:Errorinrender:"TypeError:Cannotsetpropertypropsof#whichhasonlyagetter"(foundin)我也在使用库vuedraggable但我认为这个问题更多的是Vue问题而不是vuedraggable问题。下面是我的代码。这里是draggable-list.vue可拖动列表.jsconstdraggable=require("vuedraggable");module.exports={name:"draggable-list",components:{dragga

javascript - Getter 中的异步函数 w/Return 回调

我想定义一个只读对象属性,它异步获取一个值,然后使用新的EcmaScript5getter返回它。但是,该属性始终返回undefined,即使下面示例代码中的magicValue绝对不会是未定义的。此外,当我只是return'xxx';时,打印的值仍然是undefined。它仅在我在回调函数外return时有效。无论是否调用myAsyncFunction的回调,似乎都立即执行了return。我不确定这是V8中的错误还是我在滥用JavaScript的getter。我可以让它工作吗?我想,既然我现在可以使用getters和setters,我将使用getters/setters来读写属性和常

javascript - 是否有向后兼容的方法来更新库以使用 getter?

假设一个库具有如下功能:classStuff{total(){return4;//mightbesomecalculation}}但是您想更新它以使用setter/getter,例如:classStuff{gettotal(){return4;}}有没有办法以向后兼容的方式进行这样的更改?那么使用库的代码假设函数不会中断?stuff.total//shouldworkwithnewversionstuff.total()//hopefullythisstillworks编辑:这个问题更多是关于图书馆的进化(更一般)。另一个是关于特定的解决方案,并且是从调用站点的Angular来看的。