草庐IT

anti-patterns

全部标签

ruby - "messy-polymorphism"反模式

在相当大的Ruby应用程序中,我们会遇到这样一种情况,即给定的对象由一些东西来标识:例如名称和ID。这些值类型中的每一个都有不同的用途,因此并不完全等同(id和name存在于不同的地方)。因此,我们最终在应用程序周围传递了各种值(ID、名称和对象)。这种情况至少在某种程度上似乎是个问题,因为我们已经被错误所困扰,这些错误涉及不清楚应该将什么类型传递给给定函数。事实上,我记得多年来在许多应用程序中看到过类似的问题代码,尽管我再也没有给它一个具体的名称。作为一种无类型语言,Ruby不允许像C++那样使用经典的基于类型的多态函数。作为解决方法,一位同事经常使用这种代码:definitiali

ruby-on-rails - rails : replacing try with the Null Object Pattern

在我的大多数应用程序中,我都有一个current_user方法。为了避免像current_user.name这样的情况出现异常,其中current_user是nil,rails提供了try方法。这个问题是我需要记住在current_user可能是nil的地方使用try。我想使用NullObject模式来消除这种额外的开销。classNullUserdefmethod_missing(method_name,*args)nilendenddefcurrent_userreturnNullUser.newunlessUserSession.find@current_user||=UserS

ruby - 为什么是 "wrong to require rubygems"?

根据thispost,需要ruby​​gems是一种反模式。require'rubygems'争论似乎归结为:WhenIuseyourlibrary,deployyourapp,orrunyourtestsImaynotwanttouserubygems.Whenyourequire'rubygems'inyourcode,youremovemyabilitytomakethatdecision.Icannotunrequirerubygems,butyoucannotrequireitinthefirstplace.但是,当您创建代码库并与其他人共享代码库时,对于您“需要”的任何Ru

javascript - 等待 promise 链有什么问题?

我正在开发Angular6应用程序,有人告诉我以下是反模式:awaitsomeFunction().then(result=>{console.log(result);});我意识到等待promise链是没有意义的。如果someFunction()返回一个promise,那么如果你正在等待它,你就不需要一个promise链。你可以这样做:constresult=awaitsomeFunction();console.log(result);但有人告诉我等待promise链会导致错误,或者它会破坏我的代码。如果上面的第一个代码片段与第二个代码片段做同样的事情,那么使用哪个代码片段有什么关

javascript - JS 和 OOP : abuse of `that = this` pattern

我对JS世界比较陌生。我习惯用QT编写UI(构建UI的好工具!)。使用QT,我正在为每个元素创建一个类:如果我有一个包含一些元素的表,我有一个用于每个元素的类和一个用于表的类(可能也用于行)。每个类都包含数据和操作其“DOM”的方法。现在在html中,我正在使用一些在div上包含空骨架的ejs文件,我正在编写一个类以通过jquery对其进行操作。例如:用户列表.ejs:functionUsersList(path){this.path=path;$('#userList>tbody').empty();this.loadAjax();}UsersList.prototype.loadA

javascript - D3 : data, enter, append pattern 向外部 block 添加数据

我正在使用D3javascript库来呈现一些基本的网络图表。我要加三个的元素block,但D3将元素添加到的末尾阻止。这是完整的html源代码:varchartData=[1,2,3];d3.select("html").select("body").append("svg").data(chartData,function(d){console.log("datad:",d);returnd;}).enter().append("path").attr("d",function(d){returnd;});Chrome的开发者控制台显示生成的html是:varchartData=[

javascript - Javascript 的缺点 "single var pattern"

在Stefanov的JSDesignPatterns一书中,他写道“你使用一个var语句并声明多个以逗号分隔的变量”,然后给出了一个“单一var”模式的示例,如下所示:functionfunc(){vara=1,b=2,sum=a+b,myobject={},i,j;Stefanov还写道:“在声明变量时也使用初始值对其进行初始化是一种很好的做法。”“您也可以在声明时做一些实际工作,例如前面代码中sum=a+b的情况。”现在我有一些代码如下,使用单个var模式声明了相同数量的变量,但做了更多的“声明时的实际工作”:varhtml='{purchaseQty}FR: {from

javascript - 获取 linting 错误 - 错误 Unexpected empty object pattern no-empty-pattern

我收到以下代码的linting错误-“错误意外的空对象模式no-empty-pattern”。有谁知道如何解决这个问题?它是一个tsx文件。conststateToProps=({},{data=[],filters={},staticFilters=[{}]})=>{constallFilters=staticFilters?Object.assign({},filters,...staticFilters):filters;constnewData=getFilteredRows(allFilters,data);return{data:newData,unfilteredData

javascript - 为什么来自 Promise `.then` 方法的回调是一种反模式

我在StackOverflow上看到了人们建议为AngularJS服务提供回调函数的答案。app.controller('tokenCtrl',function($scope,tokenService){tokenService.getTokens(functioncallbackFn(tokens){$scope.tokens=tokens;});});app.factory('tokenService',function($http){vargetTokens=function(callbackFn){$http.get('/api/tokens').then(functionon

javascript - 使用 "Module Pattern"时 jQuery 单击事件不起作用

我是一名中级前端JS开发人员,我正在尝试ChrisCoyyer概述的模块模式here.但是当我在设置中存储一个jQuery选择器时,我无法使用它来触发点击事件。请参阅下面的代码和我的评论...非常感谢任何帮助!vars,TestWidget={settings:{testButton:$("#testing")},init:function(){s=this.settings;this.bindUIActions();},bindUIActions:function(){console.log(s.testButton);//Thisworks:[context:document,se