머리말
기본적으로 모든 JS 데이터 유형에는 null을 제외한 이 두 가지 메소드가 있습니다. 둘 다 JavaScript 값 계산 및 표시 문제를 해결하고 다시 작성하면 호출 최적화가 향상됩니다.
테스트 분석
먼저 예시를 살펴보겠습니다.
var aaa = {
i: 10,
valueOf: function() { return this.i 30 },
toString: function() { return this.valueOf() }
}
alert(aaa > 20); // true
alert( aaa); // 40
alert(aaa) // 50
이 결과가 나온 이유 왜냐하면 그들은 비밀리에 valueOf 또는 toString 메소드를 호출하기 때문입니다.
그런데 어떤 상황에서 어떤 메서드가 호출되는지 어떻게 구별할 수 있나요? 다른 메서드를 통해 테스트해 볼 수 있습니다.
console.log를 사용하므로, Firebug가 설치된 FF에서 실험해 보세요!
var bbb = {
i: 10,
toString: function() {
console.log('toString');
return this.i;
},
valueOf: function() {
console. log(' valueOf');
return this.i;
}
}
alert(bbb); // 10 toString
alert( bbb); // 10 valueOf
alert('' bbb) // 10 valueOf
alert(String(bbb)); / 10 toString
alert(Number(bbb)); // 10 valueOf
alert(bbb == '10') // true valueOf
alert(bbb === '10'); /false
결과를 보면 문자열로 변환할 때는 toString 메소드, 수치로 변환할 때는 valueOf 메소드를 호출한 듯한 느낌을 주는데 둘은 매우 불일치합니다. 하나는 경고('' bbb)이고, 문자열 연결은 toString 메소드를 호출해야 합니다. 우리가 일시적으로 이해할 수 있는 다른 하나는 === 연산자가 암시적 변환을 수행하지 않으므로 호출되지 않는다는 것입니다. 진실을 밝히기 위해서는 좀 더 엄격한 실험이 필요합니다.
var aa = {
i: 10,
toString: function() {
console.log('toString');
return this.i
}
}
alert(aa);// 10 toString
alert( aa); // 10 toString
alert('' aa); // 10 toString
alert(String(aa)) // 10 toString
alert(Aa )); // 10 toString
alert(aa == '10'); // true toString
valueOf를 다시 살펴보세요.
var bb = {
i: 10,
valueOf: function() {
console.log('valueOf')
return this.i
}
}
alert(bb);// [객체 객체]
alert(bb); // 10 valueOf
alert('' bb) // 10 valueOf
alert(String(bb)) ; // [객체 객체]
alert(Number(bb)); // 10 valueOf
alert(bb == '10') // true valueOf
다르죠? ! 위의 toString만큼 통일되고 규칙적이지는 않습니다.
그 [객체 Object]는 Object에서 상속된 것 같습니다. 제거하고 살펴보겠습니다.
Object.prototype.toString = null
var cc = {
i: 10,
valueOf: function() {
console.log('valueOf')
return this.i;
alert(cc); // 10 valueOf
alert( cc); // 10 valueOf
alert('' cc) // 10 valueOf
alert(String(cc) ); // 10 valueOf
alert(Number(cc)); // 10 valueOf
alert(cc == '10'); // true valueOf
요약: 이는 작업에 편향되어 있고 toString은 표시에 편향되어 있습니다.
1. 객체를 변환할 때(예: 경고(a)) toString 메서드가 먼저 호출됩니다. toString이 재정의되지 않으면 valueOf 메서드가 호출되지만 toString 출력은 다음과 같습니다. 객체는 입니다.
2. 강제로 문자열 형식으로 변환하는 경우 toString 메서드가 먼저 호출되고, 강제로 숫자로 변환하는 경우 valueOf 메서드가 먼저 호출됩니다.
3. 연산 연산자가 있는 경우 valueOf가 toString보다 우선순위가 높습니다.