찾다
웹 프론트엔드JS 튜토리얼Jquery_01_isPlainObject 분석 및 재구성_javascript 기술을 넘어서

isPlainObject는 Jquery 1.4 이후에 제공되는 새로운 메서드로, 객체가 순수 객체("{}" 또는 "새 객체"를 통해 생성됨)인지 확인하는 데 사용됩니다.

isPlainObject 사용
먼저 '순수 객체'가 무엇인지 이해해 보겠습니다. '순수 객체'는 Object로 구성된 객체를 의미합니다. 그러면 어떤 객체가 Object로 구성됩니까? 부담을 가장 먼저 감당해야 하는 것은 new Object()에 의해 생성된 객체여야 합니다. 참고: Object 뒤의 괄호 안에는 아무것도 추가되지 않습니다. Object는 모든 '클래스'의 기초이기 때문에 몇 가지 특별한 동작을 갖습니다. 예를 들어 new Object(3)가 호출되면 Number 유형 객체가 생성됩니다. new Object('')는 String 유형의 객체를 생성합니다. 그러면 {} 형식으로 정의된 객체도 '순수 객체'에 속합니다. '{}'의 본질은 new Object()이지만 표현이 다릅니다. 자, 코드를 살펴보겠습니다.

코드 복사 코드는 다음과 같습니다.

var objStr = new Object('');
alert(objStr.constructor);//String
alert(isPlainObject(objStr));//false
var objNum = new Object(3) ;
alert(objNum.constructor);//Number
alert(isPlainObject(objNum));//false
function Person(){}
var person = new Person(); >alert(isPlainObject(person));//false
var obj01 = new Object();
obj01.name = '바보의 좌우명'
alert(isPlainObject(obj01));//true
alert( isPlainObject({name:'Motto of Idiot'}));//true

isPlainObject 소스 코드 분석
다음 코드는 Jquery의 isPlainObject의 전체 버전입니다. 의견은 매우 자세합니다. 더 이상 말할 것이 없습니다.

코드 복사 코드는 다음과 같습니다.
var toString = Object.prototype.toString,
hasOwnProperty = Object.prototype.hasOwnProperty;
function isPlainObject( obj ) {
// 객체여야 합니다.
// IE 때문에 생성자 속성도 확인해야 합니다. .
//DOM 노드와 창 객체도 통과하지 않도록 하세요.
//windows object:toString.call(window):IE [object Object] FF [object Window] chrome [window global] safari [객체 DOMWindow]
//DOM 노드:toString.call(#div01):IE [객체 객체] FF [객체 창] chrome [객체 전역] safari [객체 DOMWindow]
//결론: obj.nodeType || obj.setInterval은 주로 IE 브라우저를 판단하는 데 사용됩니다
//참고: 기록, 위치, 탐색기 및 화면의 setInterval은 정의되지 않습니다
if ( !obj || toString.call(obj) ! == "[object Object]" || obj.nodeType || obj.setInterval ) {
return false
}
// 자신의 생성자 속성이 Object여야 함
// 사용자 정의 개체 제거 그리고 function Person(){}과 같은 내장 객체의 판단 var p = new Person();String,Number
if ( obj.constructor //생성자 속성이 있습니다
&& !hasOwnProperty.call( obj, "constructor" ) //그리고 생성자 속성은 프로토타입 체인에 정의되어야 합니다
&& !hasOwnProperty.call(obj.constructor.prototype, "isPrototypeOf")//그리고 프로토타입에는 isPrototypeOf 메서드가 있습니다. 일반적으로 Object의 프로토타입에서만 이 메서드만
) {
return false
}
// 고유한 속성이 먼저 열거되므로 속도를 높이기 위해
// 마지막 속성이
//복잡한 클래스 구조의 경우 상속이 있는 경우...
/*
//간단한 테스트
function Animal(name){
}
function Person(이름,나이){
Animal.call(this,name);
this.age =age
}
var p = new Person('jxl', 20);
for(key in p){
alert(hasOwnProperty.call( p, key ))//true , false
}
*/
var key; for ( key in obj ) {}
return key === 정의되지 않음 || hasOwnProperty.call( obj, key );


질문하세요
이 구현이 더 복잡하고 버그가 있다고 생각합니다.
간단한 BUG, ​​​​기록, 위치, 네비게이터, 화면은 isPlainObject 감지를 통해 순차적으로 true를 반환할 수 있습니다.
제 솔루션을 살펴보겠습니다(BUG 수정, 단순화):



코드 복사 코드는 다음과 같습니다. function isPlainObject(obj){
if(obj&&Object.prototype. toString.call(obj)= ==="[object Object]"&&obj.constructor===Object &&!hasOwnProperty.call(obj, "constructor")){
var key
for ( 키 입력; obj ) {}
return key === 정의되지 않음 || hasOwnProperty.call( obj, key )
}
return false
}


또한 있습니다. BUG이며 해결 불가능한 BUG입니다.


코드 복사 코드는 다음과 같습니다.

function m(){};
m.prototype.constructor=Object; //꼭 죽여야 함
obj=new m; //true

동일한 논리를 가진 또 다른 코드:

코드 복사 코드는 다음과 같습니다. 🎜>
function m(){};
m.prototype = {};
obj=new m
alert(isPlainObject(obj)) //true

이 답변은 해결할 수 없습니다!
해결 불가 문제
이 문제는 해결하기 쉬운 문제인 줄 알았는데, 좀 더 깊이 파고들어 보니 해결 불가능한 문제였습니다. 그 이유는 다음과 같습니다.



코드 복사 코드는 다음과 같습니다. function Person( ){};
Person.prototype.constructor=Object;
var person=new Person


person의 현재 상태를 살펴보겠습니다.

person 및 해당 구성 Person 함수에 대한 유일한 연결은 해당 프로토타입 체인의 생성자 속성입니다. '순수 객체'인지 판단할 때 주로 객체 인스턴스의 생성자를 기준으로 합니다. 그림에서 볼 수 있듯이 개체를 가리키면 사람과 사람은 코드에서 아무런 관계가 없습니다. 유형 판단에 문제가 발생하는 것은 바로 이 때문이다.
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
如何使用MySQL数据库进行预测和预测分析?如何使用MySQL数据库进行预测和预测分析?Jul 12, 2023 pm 08:43 PM

如何使用MySQL数据库进行预测和预测分析?概述:预测和预测分析在数据分析中扮演着重要角色。MySQL作为一种广泛使用的关系型数据库管理系统,也可以用于预测和预测分析任务。本文将介绍如何使用MySQL进行预测和预测分析,并提供相关的代码示例。数据准备:首先,我们需要准备相关的数据。假设我们要进行销售预测,我们需要具有销售数据的表。在MySQL中,我们可以使用

如何使用 Go 语言进行数据可视化分析?如何使用 Go 语言进行数据可视化分析?Jun 10, 2023 am 10:46 AM

随着大数据时代的到来,数据可视化分析在各行各业中扮演着至关重要的角色。而Go语言作为一种快速、高效、安全的编程语言,也逐渐在数据可视化分析领域占据一席之地。本文将探讨如何使用Go语言进行数据可视化分析。一、Go语言常用的数据可视化库Plotly:可用于在浏览器中创建交互式的图形,支持多种图形类型,如线图、条形图、散点图、热力图等。Gonum/plo

Linux下的实时日志监控与分析Linux下的实时日志监控与分析Jul 29, 2023 am 08:06 AM

Linux下的实时日志监控与分析在日常的系统管理和故障排查中,日志是一个非常重要的数据来源。通过对系统日志的实时监控和分析,我们可以及时发现异常情况并进行相应的处理。本文将介绍Linux下如何进行实时日志监控和分析,并提供相应的代码示例。一、实时日志监控在Linux下,最常用的日志系统是rsyslog。通过配置rsyslog,我们可以实现将不同应用程序的日志

统计分析法的步骤统计分析法的步骤Jun 28, 2023 pm 03:27 PM

统计分析,常指对收集到的有关数据资料进行整理归类并进行解释的过程。统计分析的基本步骤包括:1、收集数据;2、整理数据;3、分析数据。

如何使用PHP进行性能分析和调优如何使用PHP进行性能分析和调优Jun 06, 2023 pm 01:21 PM

作为一种流行的服务端语言,PHP在网站开发和运行中扮演着重要的角色。然而,随着PHP代码量的不断增加和应用程序的复杂性提高,性能瓶颈也越来越容易出现。为了避免这种问题,我们需要进行性能分析和调优。本文将简单介绍如何使用PHP进行性能分析和调优,为您的应用程序提供更高效的运行环境。一、PHP性能分析工具1.XdebugXdebug是一款广泛使用的代码分析工具,

最近大火的Diffusion Model,首篇扩散生成模型综述!最近大火的Diffusion Model,首篇扩散生成模型综述!Apr 09, 2023 pm 08:31 PM

本综述(Diffusion Models: A Comprehensive Survey of Methods and Applications)来自加州大学&Google Research的Ming-Hsuan Yang、北京大学崔斌实验室以及CMU、UCLA、蒙特利尔Mila研究院等众研究团队,首次对现有的扩散生成模型(diffusion model)进行了全面的总结分析,从diffusion model算法细化分类、和其他五大生成模型的关联以及在七大领域中的应用等方面展开,

如何使用 Go 语言进行大数据分析?如何使用 Go 语言进行大数据分析?Jun 11, 2023 am 11:11 AM

随着数据规模逐渐增大,大数据分析变得越来越重要。而Go语言作为一门快速、轻量级的编程语言,也成为了越来越多数据科学家和工程师的选择。本文将介绍如何使用Go语言进行大数据分析。数据采集在开始大数据分析之前,我们需要先采集数据。Go语言有很多包可以用于数据采集,例如“net/http”、“io/ioutil”等。通过这些包,我们可以从网站、API、日志

如何利用PHP和Elasticsearch实现结果聚合和分析如何利用PHP和Elasticsearch实现结果聚合和分析Jul 17, 2023 pm 01:05 PM

如何利用PHP和Elasticsearch实现结果聚合和分析引言:随着互联网和信息技术的迅猛发展,数据量的爆炸式增长使得数据的存储、处理、分析变得越来越重要。而Elasticsearch作为一个开源的分布式搜索和分析引擎,具有强大的全文检索、实时分析和数据聚合能力,已经被广泛应用于各大行业中。在本文中,我们将介绍如何利用PHP和Elasticsearch结合

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기