- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我已经使用 javascript 一段时间了,但从未学过超过基础知识的语言。我正在阅读 John Resig 的“Pro Javascript Techniques”——我提出了一些问题,但我没有在书中或谷歌等网站上找到这些问题的答案。
约翰在他的书中给出了这个例子:
函数#1
function User( name, age ){
this.name = name;
this.age = age;
}
// Add a new function to the object prototype
User.prototype.getName = function(){
return this.name;
};
User.prototype.getAge = function(){
return this.age;
};
var user = new User( "Bob", 44 );
console.log("User: " + user.getName() + ", Age: " + user.getAge());
我还在学习 prototype 属性,所以我试着写了类似的东西:
函数 #2
function User (name, age ) {
this.name = name;
this.age = age;
this.getName = function() {
return this.name;
};
this.getAge = function() {
return this.age;
};
}
var user = new User( "Bob", 44 );
console.log("User: " + user.getName() + ", Age: " + user.getAge());
它不使用 prototype 属性来创建 getName 和 getAge 函数,但输出与 John 的示例相同。
我更进一步,创建了这个:
函数#3
var User = {
name: "",
age: 0,
setName: function(name) {
this.name = name;
},
setAge: function(age) {
this.age = age;
},
getName: function() {
return this.name;
},
getAge: function() {
return this.age;
}
};
User.setName("Bob");
User.setAge(44);
console.log("User: " + User.getName() + ", Age: " + User.getAge());
同样 - 它看起来与 John 的示例不同(我必须添加 setter 方法),但输出是相同的。
问题 #1 - 这 3 个函数有什么区别? prototype 属性的优势是什么,函数 #2 做错了什么,因为它似乎更直接地指向代码 #2 而不是 #1(尽管我确信 #1 做得更好,因为 John 创建它) .
问题 #2 - 我如何修改函数 #3 以不使用 setName 和 setAge 方法,但仍然保留 {...} 速记? {...} 速记可以有构造函数吗?
在此先感谢您帮助我学习!
编辑我认为我的第二个问题有点令人困惑。我的意思是如何使用 {...} 速记来创建一个 User 对象,但是在创建该对象之后,可以这样说:
var user = new User("Bob", 44);
就像功能 #1 中的一样 - 还是不可能?
编辑#2哇!感谢大家的精彩回答。这真的让我更清楚了。因此,如果我理解正确的话,#1 和#2 之间的差别不会太大。如果我只创建一个“用户”对象——它们可能根本没有什么不同。但是,如果我的程序创建了许多用户对象,#1 很可能会更高效并且使用更少的内存,因为所有对象都将共享相同的功能。
我非常感谢所有出色的回答 - 谢谢!
最佳答案
每次计算 function() {} 时,都会创建一个新的函数对象。因此,在#1 中,所有用户对象都共享相同的 getName 和 getAge 函数,但在#2 和#3 中,每个对象都有自己的 getName 和 getAge 副本。所有不同的 getName 函数的行为都完全相同,因此您在输出中看不到任何差异。
{...} 简写是一个构造函数。评估时,它会构造一个具有给定属性的新“对象”。当您运行“new User(...)”时,它会构造一个新的“User”。您碰巧创建了一个与用户具有相同行为的对象,但它们属于不同类型。
评论回复:
你不能,直接。您可以根据 #3 创建一个创建新对象的函数。例如:
function make_user(name, age) {
return {
name: name,
age: age,
getName: function() { return name; },
getAge: function() { return age; },
};
}
var user = make_user("Joe", "18");
关于javascript - Javascript 中的面向对象问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/444170/
我想做的是让 JTextPane 在 JPanel 中占用尽可能多的空间。对于我使用的 UpdateInfoPanel: public class UpdateInfoPanel extends JP
我在 JPanel 中有一个 JTextArea,我想将其与 JScrollPane 一起使用。我正在使用 GridBagLayout。当我运行它时,框架似乎为 JScrollPane 腾出了空间,但
我想在 xcode 中实现以下功能。 我有一个 View Controller 。在这个 UIViewController 中,我有一个 UITabBar。它们下面是一个 UIView。将 UITab
有谁知道Firebird 2.5有没有类似于SQL中“STUFF”函数的功能? 我有一个包含父用户记录的表,另一个表包含与父相关的子用户记录。我希望能够提取用户拥有的“ROLES”的逗号分隔字符串,而
我想使用 JSON 作为 mirth channel 的输入和输出,例如详细信息保存在数据库中或创建 HL7 消息。 简而言之,输入为 JSON 解析它并输出为任何格式。 最佳答案 var objec
通常我会使用 R 并执行 merge.by,但这个文件似乎太大了,部门中的任何一台计算机都无法处理它! (任何从事遗传学工作的人的附加信息)本质上,插补似乎删除了 snp ID 的 rs 数字,我只剩
我有一个以前可能被问过的问题,但我很难找到正确的描述。我希望有人能帮助我。 在下面的代码中,我设置了varprice,我想添加javascript变量accu_id以通过rails在我的数据库中查找记
我有一个简单的 SVG 文件,在 Firefox 中可以正常查看 - 它的一些包装文本使用 foreignObject 包含一些 HTML - 文本包装在 div 中:
所以我正在为学校编写一个 Ruby 程序,如果某个值是 1 或 3,则将 bool 值更改为 true,如果是 0 或 2,则更改为 false。由于我有 Java 背景,所以我认为这段代码应该有效:
我做了什么: 我在这些账户之间创建了 VPC 对等连接 互联网网关也连接到每个 VPC 还配置了路由表(以允许来自双方的流量) 情况1: 当这两个 VPC 在同一个账户中时,我成功测试了从另一个 La
我有一个名为 contacts 的表: user_id contact_id 10294 10295 10294 10293 10293 10294 102
我正在使用 Magento 中的新模板。为避免重复代码,我想为每个产品预览使用相同的子模板。 特别是我做了这样一个展示: $products = Mage::getModel('catalog/pro
“for”是否总是检查协议(protocol)中定义的每个函数中第一个参数的类型? 编辑(改写): 当协议(protocol)方法只有一个参数时,根据该单个参数的类型(直接或任意)找到实现。当协议(p
我想从我的 PHP 代码中调用 JavaScript 函数。我通过使用以下方法实现了这一点: echo ' drawChart($id); '; 这工作正常,但我想从我的 PHP 代码中获取数据,我使
这个问题已经有答案了: Event binding on dynamically created elements? (23 个回答) 已关闭 5 年前。 我有一个动态表单,我想在其中附加一些其他 h
我正在尝试找到一种解决方案,以在 componentDidMount 中的映射项上使用 setState。 我正在使用 GraphQL连同 Gatsby返回许多 data 项目,但要求在特定的 pat
我在 ScrollView 中有一个 View 。只要用户按住该 View ,我想每 80 毫秒调用一次方法。这是我已经实现的: final Runnable vibrate = new Runnab
我用 jni 开发了一个 android 应用程序。我在 GetStringUTFChars 的 dvmDecodeIndirectRef 中得到了一个 dvmabort。我只中止了一次。 为什么会这
当我到达我的 Activity 时,我调用 FragmentPagerAdapter 来处理我的不同选项卡。在我的一个选项卡中,我想显示一个 RecyclerView,但他从未出现过,有了断点,我看到
当我按下 Activity 中的按钮时,会弹出一个 DialogFragment。在对话框 fragment 中,有一个看起来像普通 ListView 的 RecyclerView。 我想要的行为是当
我是一名优秀的程序员,十分优秀!