- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的问题是关于 javascript 中的函数和对象。我有三个问题,从一个到另一个。在下面的示例中,我尝试在测试中访问 'a' 的值,但我得到了未定义的值。但是我创建了一个新的测试对象,然后我可以访问“a”值并更改它。
//create a function called test
var test=function() {
this.a=2
this.b=3 };
test.a//undefined
//create a object called test1 using 'new'
test1 = new test();
test1.a//2
//change the value of a in test1
test1.a=4
test1 //Object { a=4, b=3}
在试图找出发生这种情况的原因时,我遇到了这个 javascript functions are objects?另一个问题由此而生。该 SO 问题的公认解决方案如下
var addn = function func(a) {
return func.n + a;
};
addn['n'] = 3;
addn(3);
我将“func.n”更改为“this”,但它不再有效
var addn=function func(a) {
return this.n+a;
};
addn['n']=3;
addn(3); //NaN
用'this'创建匿名函数也没有帮助
//anonymous function
var addn=function(a) {
return this.n+a;
};
addn['n']=3;
addn(3); //NaN
为什么使用“this”不起作用?
最后一个问题,使用关键字“new”和“createObject”有什么区别。 Douglas Crokford 建议在他的书中使用“CreateObject”,但我不明白为什么。谢谢大家的意见
最佳答案
当你调用new FuncName
时,该函数作为一个构造函数,里面的this
的值指向被构造的对象(而不是函数本身)。当您删除 new
时,this
变为 undefined
,退回到全局对象(除非您处于严格模式)。
每个函数都是Function
的一个实例,所以函数本身也是对象并且可以有自己的属性。这些属性无法通过函数体内的 this.propName
访问,只能通过 funcName.propName
访问。那是因为函数内部的 this
从不 函数对象本身(除非你强制它是,使用 bind
,call
,或 apply
)。
我希望以上两个主题能帮助您了解函数的工作原理。至于你的最后一个问题:Crockford 的 createObject
是实现继承的另一种方式,基本上做了 Object.create
的事情。在兼容 ES5 的浏览器中执行。它允许一个对象直接从另一个对象继承,而不需要你手动创建一个新的构造函数,设置它的 prototype
属性(这是一个函数对象的属性的例子),并创建一个实例使用 new
。 Crockford 更喜欢这种方式,并表示他不再使用 new
来支持这种方法。
In response to the questions you asked in chat, here is an attempt to explain what functions are and what they do, with examples.
你调用他们,他们会做一些事情:
function alertThis(what) {
alert(what)
}
alertThis("alerting something");
你也可以给它们传值,让它们返回值
function timesTwo(num) {
return num * 2;
}
timesTwo(2); // 4
它们可以被传递并返回任何东西,包括对象...
function createPerson(firstName, lastName) {
return {
firstName : firstName,
lastName : lastName
}
}
var john = createPerson('John', 'Doe');
john.lastName; // "Doe"
...和其他功能:
function timesN(n) {
return function(num) {
return n * num;
}
}
var timesThree = timesN(3);
timesThree(5); // 15
函数可以像任何普通对象一样传递和返回。那是因为它们是对象。与任何对象一样,它们可以具有属性:
function countCalls() {
countCalls.timesCalled++;
}
countCalls.timesCalled = 0;
countCalls();
countCalls();
countCalls.timesCalled; // 2
函数的一个非常重要的默认属性是prototype
。这是一个特殊的属性,我们将了解原因。
函数的行为可以像常规 OO 语言中的类构造函数一样。 当使用 new
调用时,它们会创建一个特定“类”的新对象。这个新对象在函数内部称为 this
,并自动返回:
function Person(firstName, lastName) {
this.firstName = firstName;
this.lastName = lastName;
}
var john = new Person('John', 'Doe');
john.firstName; // "John"
john instanceof Person; // true
...除非你故意返回其他东西:
function Person(firstName, lastName) {
this.firstName = firstName;
this.lastName = lastName;
var fakePerson = {
firstName : firstName,
lastName : lastName
};
return fakePerson;
}
var notPerson = new Person('John', 'Doe');
notPerson.firstName; // "John"
notPerson instanceof Person; // false
// Note: the object called 'this' inside the function is created, but
// after the function is called there is no outside reference to it.
prototype
属性回到真人:
function Person(firstName, lastName) {
this.firstName = firstName;
this.lastName = lastName;
}
// Add something to the Person prototype
Person.prototype.sayHi = function() {
return "hi, I'm " + this.firstName;
}
var john = new Person('John', 'Doe');
john.sayHi(); // "Hi, I'm John"
john.constructor; // Person
对象 john
可以 sayHi()
因为它可以访问其构造函数的 prototype
属性中的所有内容。但是它不能直接看到 Person 的其他属性(只能通过它们自己的 constructor
属性):
function Person(firstName, lastName) {
this.firstName = firstName;
this.lastName = lastName;
Person.timesCalled++;
// There is no 'this.timesCalled', only Person.timesCalled
}
Person.timesCalled = 0;
var john = new Person('John', 'Doe');
john.timesCalled; // undefined - john cannot be called, Person can
john.constructor.timesCalled; // 1
关于使用关键字 'this' 的 javascript 函数和对象不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17200558/
如果我创建一个对象时没有使用 new 关键字,例如“Object s(someval)”,但该对象的构造函数使用了 new,当该对象超出范围时,是否会调用析构函数为其分配新的空间?我感觉好像是,但我不
在 SQL 语法中,我发现奇怪的规则表明 select * from ONLY (t1)是有效的 SQL。 我的问题是:什么是 ONLY在这种情况下是什么意思? 它在规范的“7.6 table ref
为什么使用 $(this) 而不是重新选择类很重要? 我在代码中使用了大量的动画和 CSS 编辑,并且我知道可以使用 $(this) 来简化它。 最佳答案 当您通过 jQuery 执行 DOM 查询(
我正在尝试使用 IN 关键字编写查询。 表A 属性标识、属性名称 表B key 、属性标识、属性值 根据提供的 key ,我想返回所有 attrName、attrVal 组合。结果将包含两个表中的列。
这个问题在这里已经有了答案: Why would you use "AS" when aliasing a SQL table? (8 个答案) 关闭 9 年前。 我不擅长写查询,但是从我开始使用
我读过,在 Java 中,您不必将 this 关键字显式绑定(bind)到对象,它由解释器完成。它与 Javascript 相反,在 Javascript 中你总是必须知道 this 的值。但是 Ja
Swift 中“with”关键字的用途是什么?到目前为止,我发现如果您需要覆盖现有的全局函数,例如 toDebugString,可以使用该关键字。 // without "with" you
这个问题在这里已经有了答案: What does the keyword "where" in a class declaration do? (7 个答案) 关闭 9 年前。 在下面的一段代码中(
免责声明:swift 菜鸟 您好,我刚刚开始学习 Swift,正在学习 Swift 编程语言(Apple 在 WWDC 期间发布的书籍),并且想知道“where”关键字是什么。它用于 let vege
深入研究文档后,我找不到以下问题的答案: 是否有任何理由反对使用 this 来引用当前对象,如下例所示? type MyStruct struct { someField string } fun
前言 最近在做THINKPHP开发项目中,用到了 parent:: 关键字,实际上 parent::关键字 是PHP中常要用到的一个功能,这不仅仅是在 THINKPHP 项目开发中,即使是一个小型
我们都知道且经常用到 unsigned 关键字,但有没有想过,与此对应的 signed 关键字有啥用? 复制代码 代码如下: int i = 0; signed
this关键字再java里面是一个我认为非常不好理解的概念,:)也许是太笨的原因 this 关键字的含义:可为以调用了其方法的那个对象生成相应的句柄。 怎么理解这段话呢? thinking i
一 什么是 synchronized synchronized 关键字提供了一种锁机制,能够确保共享变量互斥访问,从而防止数据不一致问题的出现。 synchronized 关键字包括 monitor
最近看了几篇 synchronized 关键字的相关文章,收获很大,想着总结一下该关键字的相关内容。 1、synchronized 的作用 原子性:所谓原子性就是指一个操作或者多个操作,要么全部执行并
在本教程中,您将借助示例了解 JavaScript 对象方法和 this 关键字。 在 JavaScript 中,对象也可以包含函数。例如, // object containing meth
有人可以解释一下 PHP“with”的作用吗? 示例开始: 假设我有一个类: \App\fa_batch 这句话有什么区别: $w = (with (new \App\fa_batch))
这个问题在这里已经有了答案: What is the difference between using the colon and as syntax for declaring type? (2
如果我在 WHERE 子句中使用以下任一项,是否会有很大不同: WHERE [Process Code] = 1 AND ([Material ID] = 'PLT' OR [Material ID]
This question is unlikely to help any future visitors; it is only relevant to a small geographic are
我是一名优秀的程序员,十分优秀!