草庐IT

vuex中this.$store.commit和this.$store.dispatch的用法

全部标签

javascript - require() : using module. 导出 vs 直接分配给 "this"

我想知道将这两种方法相互对抗时是否有任何优点或缺点:首先.js:this.myFunction=function(){return'herrofirst';}second.js:module.exports=obj={};obj.myFunction=function(){return'herrosecond';}以上两个将被包含并按如下方式使用:应用程序.js:varfirst=require('./first.js');console.log(first.myFunction());varsecond=require('./second');console.log(second.m

javascript - 更改 "this"变量的函数

我是JavaScript的新手,正在尝试了解OOP和模拟“类”的一些基础知识。在执行该脚本的最后一行时,我希望第4行调用的this对象指针指向farm对象(就像它在第2行中正确执行的那样,并且3).不幸的是它没有,我猜this对象指针指向document。varBuilding=function(cost){this.cost=cost;this.printCost=function(){document.getElementById(this).innerHTML=this.cost;}}varfarm=newBuilding(50);farm.printCost();-有没有办法让

javascript - 导入 redux store 未定义(加载顺序问题?)

更新2-添加显示问题的最小“工作”示例我尽可能地缩减了项目,同时仍然显示问题,让人们在感兴趣的情况下尝试想法/调试github:store_import_test错误发生在:request.js注意:我知道赏金即将到期,但如果发生这种情况,我会重新启用它。我非常感谢到目前为止提出的所有想法/帮助!结束更新2更新1-目的说明:我想在“效用函数”中访问存储中的一个值(可以随时间改变)。根据reduxdocssubscribe是一个有效的选项。结束更新我正在尝试在组件外部导入我的redux-store(在request.js中,见下文)类似于:Whatisthebestwaytoaccess

javascript - 创建和分派(dispatch)自定义 Javascript 事件是否被认为是一种好的做法?

我的Web应用程序使用document.createEvent和event.initEvent创建通用类型Event的自定义事件。我想知道这是否被认为是好的做法。另一方面,这样我可以利用已经存在的DOM事件系统,而不必发明和实现我自己的;另一方面,如果future的标准化事件模型使用我选择的名称定义事件类型,这可能会导致名称冲突。(或者是否可以命名事件类型?)我问是因为我刚刚通过浏览stackoverflow了解到,将自定义属性放在DOM对象或内置Javascript对象上被认为是不好的做法。编辑我想我找到了一些东西:http://dev.w3.org/2006/webapi/DOM-

javascript - this.domNode 为空

我正在尝试使用jquery加载dojo图表。我正在使用这段代码。但是在第二次单击时,在第一个按钮中出现此错误。如果我单击第一个按钮,单击第二个按钮,然后再次单击第一个按钮,也会发生同样的情况。这个问题快把我逼疯了。demohere$(document).ready(function(){$('.lista_').click(function(){$.get('index1.php',function(data){dojo.addOnLoad(function(){require(["dojo/_base/xhr","dojo/parser","dojo/dom"],function(x

javascript - 'this' 在 Javascript 函数中指的是什么

我理解this关键字背后的一般概念,但我很难弄清楚它在实践中实际指的是什么。例如,在这两个示例练习中,我都猜错了数字。对于问题1,我说alert会是'5',因为它指的是函数中匿名函数外的this.x。在问题2中,我认为警报会是5,因为这一行varalertX=o.alertX;会将变量o内属性x的值5绑定(bind)到新变量“alertX”,该变量成为下一行中的函数调用:alertX();你能解释一下为什么我错了吗?varquestion1=function(){this.x=5;(function(){varx=3;this.x=x;})();alert(this.x);};vara

javascript - this.someFunction.call(this, param); 的目的是什么?

我在很多地方都遇到过一些具有这种模式的代码:this.someFunction.call(this,param);但在我看来这只是一种更冗长的打字方式this.someFunction(param)该模式有时会出现在作为回调提供的函数中。如果相关的话,它恰好使用了Backbone。像这样:Backbone.View.extend({//otherstuff...someFunction:function(param){//...},anotherFunction:function(){this.collection.on("some_event",function(){this.som

javascript - 如何在单例模式中保留 javascript "this"上下文?

我有类似的东西:vara=(function(){return{b:1,c:function(){console.log(this.b);}};})();所以,a.c();//=1但如果我这样做b=2;a.c.apply(this);//=2是否有可能在不改变(太多)“a”对象的结构的情况下在“a.c()”中保留“this”的上下文?我无法控制函数的调用,因此我需要一种变通方法来在对象本身内部处理此问题。更新:更具体地说,这是我的文件结构:结构一(类单例模式):vara=(function(){var_instance;functioninit(){return{b:1,c:funct

javascript - 用于本地编辑的 Vuex 克隆对象

我正在使用Vue和Vuex进行中央存储管理。我在商店中有一个经常由setTimeout函数更新的对象列表。我想让用户使用双向数据绑定(bind)表单来选择和编辑它。我的问题是,每当商店中的任何数据更新时,用户正在修改的选定对象也会重新呈现。这样,用户将丢失更改。解决方案是将对象从Vuex存储克隆到本地数据对象并将其绑定(bind)到表单以防止在编辑时更新。我尝试了所有可能的方法来克隆Vuex返回的可观察对象,但没有成功。特别是我尝试了以下方法:JSON.parse(JSON.stringify(obj))和Object.assign({},vueObj)以及来自外部库(如_和jQuer

javascript - 'this'关键字在原型(prototype)链中是如何工作的?

您好专家,这是我的代码,我对this关键字如何向对象添加属性感到困惑。functioncarMaker(){this.companyName='Lamborghini';}letLamborghiniUrus=newcarMaker();carMaker.prototype.country="Italy"LamborghiniUrus.price="200000";我知道用this和Object.prototype添加的属性会继承给所有对象,但两者是等价的,即this也在添加属性到原型(prototype)?如果是那么为什么console.log(carMaker.prototype.