我在阅读 emberjs.com 上的文档时感到困惑
http://emberjs.com/documentation/#toc_reopening-classes-and-instances
在上面的页面上,它是这样解释的。
Person.reopen({
// override `say` to add an ! at the end
say: function(thing) {
this._super(thing + "!");
}
});
As you can see, reopen is used to add properties and methods to an instance. But when you need to create class method or add the properties to the class itself you can use reopenClass.
Person.reopenClass({
createMan: function() {
return Person.create({isMan: true})
}
});
Person.createMan().get('isMan') // true
最佳答案
文档没有很好地解释这一点,但它 是 一个非常棘手的话题。
顺便说一句,它现在住在:
http://emberjs.com/guides/object-model/reopening-classes-and-instances/
谈论面向对象编程的问题之一是它经常被这样解释:
- 对象就是对象。对象是类的实例。
- 类是对象。
- 实例是对象,并且有一个类。
这个解释没有帮助任何人根本没有,并且似乎是一个递归问题(即引用没有尽头......一个对象是一个类的实例,它是一个对象......(重复))。
我更喜欢用以下方式推理:
人们在编写代码时,通常会描述类和实例。类是一种东西。 Fruit 是一个类的例子。我们在这里不是在谈论特定的事情,而是在谈论整个“类”的事情(因此得名)。
请注意,这不是一个真正的类。它只有在“实时”和“在计算机内存中”时才是真实的。在那之前,它是一个类的描述。通常当人们编写代码时,他们在文本文件中编写文本,这只是对计算机内部真实代码的描述,当计算机将其解释或编译为机器代码时发生。
当您意识到一个类实际上也是一个描述时,棘手的一点就来了。它是对一系列潜在真实物体的描述。
在计算机中,当您创建“一个苹果”时,就是一个实例。也是一个对象。它的类是 Apple,它在计算机中也是一个真实的活对象。当我们谈论苹果,这是一个想法。它在现实中并不存在,但计算机要使用某种东西就必须使其存在于现实中,因此“Apple”是一个具体的、真实的对象,尽管它也是一种抽象。
我认为最后一点是让人们对对象感到困惑的原因。类是抽象的,但为了让计算机谈论和推理它们,它们必须是真实的。所以,我们决定......“类意味着抽象,实例意味着真实”......
问题是,我们有继承......这带来了的想法。层抽象......所以在我们的水果模型中,你面前有一个特定的苹果,它也是水果,水果也是一种食物。实际上,食物实际上并不作为一个事物或一组事物存在,除非我们说“这个食物,这个苹果”,或者“世界上所有的食物”,或者“你妈妈的千层面”,那么它就是一个抽象的概念...
所以,在我们的面向对象计算机中,我们说“定义食物是一种对象,现在定义水果是一种食物,现在定义苹果是一种水果,现在定义这个苹果,它是一种苹果”。
现在这意味着:
- Object是Food的类,Food是Object的一个实例,Food本身也是一个类!
- Food 是 Fruit 的类,而 Fruit 是 Food 的一个实例,而 Fruit 本身也是一个类!
- Fruit是Apple的类,Apple是Fruit的一个实例,Apple本身也是一个类!
- Apple 是您的 Apple 的类,您的 Apple 是 Apple 的一个实例(因此也是 Fruit、Food 和 Object!)。然而,它不是一个类,它只是一个对象。
为了推理你的苹果,我们会说它是一个对象(注意小写的 o),它也是一个苹果,一个水果和一个食物,而且......这是踢球者......它也是一个对象。
所以现在希望我们能够理解你的苹果是一个对象,一个实例(苹果,水果,食物和对象),一个苹果,一个水果,一个食物和一个对象,但它不是一个类.
所以...如果你添加一个 实例方法到一个类,那么它在该类上将不可用,但它将在该类的所有实例上可用。如果您添加一个类方法,它将在该类(和子类)上可用。因此,如果您向 Apple 添加一个实例方法,那么 Apple 的所有实例都将能够运行该方法。但是,如果你只为你的苹果添加一个方法,那么只有你的苹果才会有那个方法。我的苹果不会。如果您向 Apple 添加类方法,则只有 Apple 类能够运行该方法(您也可以方便地通过其所有实例进行访问)。类方法用于不改变的东西 特别实例。实例方法用于更改的事物 特别实例(一般)。属性/属性也是如此。您不会在 Apple 类上创建名为“Apple colour”的类方法,因为这听起来与 有关。特别苹果(即实例)。希望能把事情弄清楚一点:)
关于javascript - Ember.js 中重新打开()和重新打开类()之间的区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14026302/
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此
鉴于我有以下迁移:Sequel.migrationdoupdoalter_table:usersdoadd_column:is_admin,:default=>falseend#SequelrunsaDESCRIBEtablestatement,whenthemodelisloaded.#Atthispoint,itdoesnotknowthatusershaveais_adminflag.#Soitfails.@user=User.find(:email=>"admin@fancy-startup.example")@user.is_admin=true@user.save!ende
我正在使用active_admin,我在Rails3应用程序的应用程序中有一个目录管理,其中包含模型和页面的声明。时不时地我也有一个类,当那个类有一个常量时,就像这样:classFooBAR="bar"end然后,我在每个必须在我的Rails应用程序中重新加载一些代码的请求中收到此警告:/Users/pupeno/helloworld/app/admin/billing.rb:12:warning:alreadyinitializedconstantBAR知道发生了什么以及如何避免这些警告吗? 最佳答案 在纯Ruby中:classA
请帮助我理解范围运算符...和..之间的区别,作为Ruby中使用的“触发器”。这是PragmaticProgrammersguidetoRuby中的一个示例:a=(11..20).collect{|i|(i%4==0)..(i%3==0)?i:nil}返回:[nil,12,nil,nil,nil,16,17,18,nil,20]还有:a=(11..20).collect{|i|(i%4==0)...(i%3==0)?i:nil}返回:[nil,12,13,14,15,16,17,18,nil,20] 最佳答案 触发器(又名f/f)是
在Cooper的书BeginningRuby中,第166页有一个我无法重现的示例。classSongincludeComparableattr_accessor:lengthdef(other)@lengthother.lengthenddefinitialize(song_name,length)@song_name=song_name@length=lengthendenda=Song.new('Rockaroundtheclock',143)b=Song.new('BohemianRhapsody',544)c=Song.new('MinuteWaltz',60)a.betwee
我正在检查一个Rails项目。在ERubyHTML模板页面上,我看到了这样几行:我不明白为什么不这样写:在这种情况下,||=和ifnil?有什么区别? 最佳答案 在这种特殊情况下没有区别,但可能是出于习惯。每当我看到nil?被使用时,它几乎总是使用不当。在Ruby中,很少有东西在逻辑上是假的,只有文字false和nil是。这意味着像if(!x.nil?)这样的代码几乎总是更好地表示为if(x)除非期望x可能是文字false。我会将其切换为||=false,因为它具有相同的结果,但这在很大程度上取决于偏好。唯一的缺点是赋值会在每次运行
我正在阅读一本关于Ruby的书,作者在编写类初始化定义时使用的形式与他在本书前几节中使用的形式略有不同。它看起来像这样:classTicketattr_accessor:venue,:datedefinitialize(venue,date)self.venue=venueself.date=dateendend在本书的前几节中,它的定义如下:classTicketattr_accessor:venue,:datedefinitialize(venue,date)@venue=venue@date=dateendend在第一个示例中使用setter方法与在第二个示例中使用实例变量之间是
我早就知道Ruby中的“常量”(即大写的变量名)不是真正常量。与其他编程语言一样,对对象的引用是唯一存储在变量/常量中的东西。(侧边栏:Ruby确实具有“卡住”引用对象不被修改的功能,据我所知,许多其他语言都没有提供这种功能。)所以这是我的问题:当您将一个值重新分配给常量时,您会收到如下警告:>>FOO='bar'=>"bar">>FOO='baz'(irb):2:warning:alreadyinitializedconstantFOO=>"baz"有没有办法强制Ruby抛出异常而不是打印警告?很难弄清楚为什么有时会发生重新分配。 最佳答案
📢博客主页:https://blog.csdn.net/weixin_43197380📢欢迎点赞👍收藏⭐留言📝如有错误敬请指正!📢本文由Loewen丶原创,首发于CSDN,转载注明出处🙉📢现在的付出,都会是一种沉淀,只为让你成为更好的人✨文章预览:一.分辨率(Resolution)1、工业相机的分辨率是如何定义的?2、工业相机的分辨率是如何选择的?二.精度(Accuracy)1、像素精度(PixelAccuracy)2、定位精度和重复定位精度(RepeatPrecision)三.公差(Tolerance)四.课后作业(Post-ClassExercises)视觉行业的初学者,甚至是做了1~2年