Chrome 에서 JSON.parse 의 특별한 실현
var str = '{"name":"jack"}';
var json = JSON.parse(str);
alert(json.name);
모든 대상 이 Object 의 방법 을 물 려 받 았 기 때문에 이 럴 때 직접 사용 할 수 있 습 니 다
Object.prototype.parseJSON = function () {
return JSON.parse(this);
}
str.parseJSON()때 parseJSON 내부 의 this 는 str 를 가리 키 고 있 습 니 다.이 때 모든 브 라 우 저가 성공 적 으로 해석 되 는 것 은 아니다.IE8/Firefox/safari/Opera 는 여전히"jack"을 팝 업 하고 크롬 에 서 는"Uncaught illegal access"를 잘못 알 렸 습 니 다.왜 이렇게 크롬 을 쓰 면 지원 하지 않 습 니까?두 가지 방식 을 비교 해 보면 JSON.parse 에 전 달 된 매개 변 수 는 문자열 str 이 고 하 나 는 this 입 니 다.이 두 개 다 를 게 없 는 것 같은 데?str.parseJSON()일 때 parseJSON 내부 의 this 가 가리 키 는 것 은 str 일 것 이다.parseJSON 방법 을 수정 합 니 다
var str = '{"name":"jack"}';
var json = str.parseJSON();
alert(json.name);
다시 실행 하면 parseJSON 이 튀 어 나 온 것 이 object 라 는 것 을 알 수 있 습 니 다.이것 이 차이 일 수 있 습 니 다.new 문자열 을 직접 사용 하면 뚜렷 한 효 과 를 볼 수 있 습 니 다.기본적으로 결론 을 내 렸 습 니 다.Chrome 에서 JSON.parse 의 첫 번 째 매개 변 수 는 문자열 일 수 있 습 니 다.대상 일 수 없습니다(new String 방식 도 지원 되 지 않 습 니 다)다시 위로 돌아 가서 Object.prototype 에 json 을 해석 하 는 방법 을 추가 합 니 다.모든 브 라 우 저 를 호 환 하려 면 이렇게 쓸 수 있 습 니 다
Object.prototype.parseJSON = function () {
alert(typeof this);
return JSON.parse(this);
};
2010-10-09:이 BUG 는 Chrome 6 에서 복구 되 었 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
스마트 폰 버전 Qiita에서 새로운 기사를 만드는 버튼을 모르기 때문에 QiitaAPI를 사용하여 어떻게 하는지 테스트오랜만에 신규 기사를 쓰려고 하면, 「작성 버튼…어디?」가 되어 전혀 발견되지 않았기 때문에, QiitaAPI와 Shortcuts로 어떻게든 한 이야기. 사용할 수 있는 도구는 스마트폰만(PC는 사용하지 않는다) S...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.