jquery 상위 버전에 prop 메서드가 도입된 후 언제 prop을 사용해야 합니까? attr은 언제 사용하나요? 둘 사이의 차이점은 무엇입니까? 이러한 문제가 발생합니다.
둘의 차이점에 대한 답변이 온라인에 많이 있습니다. 다음은 매우 간단한 경험입니다.
HTML 요소의 고유한 속성을 처리할 때 prop 메서드를 사용하세요.
HTML 요소의 자체 사용자 정의 DOM 속성을 처리하려면 attr 메소드를 사용하세요.
jQuery에서는 attr() 함수와 prop() 함수 모두 지정된 속성을 설정하거나 가져오는 데 사용되며 해당 매개변수와 사용법은 거의 동일합니다.
하지만 이 두 기능의 용도는 동일하지 않습니다. 이 두 기능의 차이점을 자세히 소개하겠습니다.
1. 작업 개체가 다릅니다
분명히 attr과 prop은 각각 attribute와 property라는 단어의 약어이며 둘 다 "속성"을 의미합니다.
그러나 jQuery에서는 속성과 속성이 서로 다른 개념입니다. Attribute는 HTML document 노드의 속성을 나타내고, property는 JS 객체의 속성을 나타냅니다.
<!-- 这里的id、class、data_id均是该元素文档节点的attribute --> <p id="message" class="test" data_id="123"></p> <script type="text/javascript"> // 这里的name、age、url均是obj的property var obj = { name: "CodePlayer", age: 18, url: "http://www.php.cn/" }; </script>
jQuery에서 prop() 함수의 설계 목표는 지정된 DOM 요소(JS 객체, 요소 유형 참조)에 속성(property)을 설정하거나 가져오는 것입니다. attr() 함수의 설계 목표는 다음과 같습니다. 지정된 DOM 요소에 해당하는 문서 노드의 속성을 설정하거나 가져오는 것입니다.
<!-- attr()函数针对的是该文档节点的attribute --> <p id="message" class="test" data_id="123"></p> <script type="text/javascript"> // prop()函数针对的是该DOM元素(msg)自身的property var msg = document.getElementById("message"); var $msg = $(msg); </script>
물론, jQuery의 기본 구현에서 attr() 및 prop() 함수의 함수는 JS 기본 요소 개체(예: 위 코드의 msg)를 통해 구현됩니다. attr() 함수는 주로 Element 객체의 getAttribute() 및 setAttribute() 메서드에 의존합니다. prop() 함수는 주로 JS의 기본 객체 속성 획득 및 설정 방법에 의존합니다.
<p id="message" class="test" data_id="123"></p> <script type="text/javascript"> var msg = document.getElementById("message"); var $msg = $(msg); /* *** attr()依赖的是Element对象的element.getAttribute( attribute ) 和 element.setAttribute( attribute, value ) *** */ // 相当于 msg.setAttribute("data_id", 145); $msg.attr("data_id", 145); // 相当于 msg.getAttribute("data_id"); var dataId = $msg.attr("data_id"); // 145 /* *** prop()依赖的是JS原生的 element[property] 和 element[property] = value; *** */ // 相当于 msg["pid"] = "pid值"; $msg.prop("pid", "pid值"); // 相当于 msg["pid"]; var testProp = $msg.prop("pid"); // pid值 </script>
물론, jQuery는 이러한 작업을 캡슐화하여 작업을 더 편리하게 만들고(예: 개체 형태로 동시에 여러 속성 설정) 브라우저 간 호환성을 달성합니다.
또한 prop()은 요소 노드의 속성이 아닌 DOM 요소의 속성을 대상으로 합니다. 그러나 DOM 요소의 일부 속성을 변경하면 요소 노드의 해당 속성에도 영향을 미칩니다. 예를 들어 속성의 id는 속성의 id에 해당하고 속성의 className은 속성의 클래스에 해당합니다.
<p id="message" class="test" data_id="123"></p> <script type="text/javascript"> var msg = document.getElementById("message"); var $msg = $(msg); document.writeln( $msg.attr("class") ); // test $msg.prop("className", "newTest"); // 修改className(property)导致class(attitude)也随之更改 document.writeln( $msg.attr("class") ); // newTest </script>
2. 다양한 애플리케이션 버전
attr()은 jQuery 버전 1.0에 존재하는 함수이고 prop()은 jQuery 버전 1.6의 새로운 함수입니다. 1.6 이전에는 1.6 이상 버전에서만 attr() 함수를 사용할 수 있었으며 실제 필요에 따라 해당 함수를 선택할 수 있다는 것은 의심의 여지가 없습니다.
3. 설정에 사용되는 속성 값의 유형이 다릅니다
attr() 함수는 문서 노드의 속성에 대해 작동하므로 속성 값 세트는 그렇지 않은 경우에만 string 유형일 수 있습니다. 문자열 유형인 경우에도 호출됩니다. toString() 메소드는 이를 문자열 유형으로 변환합니다.
prop() 함수는 JS 객체의 속성에 대해 작동하므로 설정된 속성 값은 배열, 객체를 포함한 모든 유형이 될 수 있습니다.
4. 기타 세부사항
jQuery 1.6 이전에는 attr() 함수만 사용할 수 있었습니다. 이 함수는 속성을 설정하고 가져오는 것뿐만 아니라 속성을 설정하고 가져오는 역할도 담당했습니다. 예를 들어 jQuery 1.6 이전에는 attr()이 tagName, className, nodeName, nodeType 등과 같은 DOM 요소의 속성을 설정하거나 가져올 수도 있었습니다.
jQuery 1.6에 prop() 함수가 추가되고 속성을 설정하거나 가져오는 데 사용되기 전까지 attr()은 속성을 설정하고 가져오는 데만 사용되었습니다.
또한 양식 요소의 확인됨, 선택됨, 비활성화됨 및 기타 속성에 대해 jQuery 1.6 이전에는 attr()이 이러한 속성의 반환 값을 부울 유형으로 얻었습니다. 선택(또는 비활성화)된 경우 true를 반환합니다. , 그렇지 않으면 false를 반환합니다.
그러나 1.6부터는 attr()을 사용하여 이러한 속성의 반환 값을 문자열 유형으로 가져옵니다. 선택(또는 비활성화)되면 선택됨, 선택됨 또는 비활성화됨을 반환합니다. 즉, 요소 노드는 이 속성이 없음)은 정의되지 않음을 반환합니다. 또한 일부 버전에서는 이러한 속성 값이 문서가 로드될 때 초기 상태 값을 나타내므로 나중에 해당 요소의 선택(또는 비활성화) 상태가 변경되더라도 해당 속성 값은 변경되지 않습니다.
jQuery는 속성의 선택, 선택 및 비활성화가 속성의 초기 상태 값을 나타내고 속성의 선택, 선택 및 비활성화가 속성의 실시간 상태 값(값은 true 또는 false)을 나타낸다고 믿기 때문입니다.
따라서 jQuery 1.6 이상 버전에서는 prop() 함수를 사용하여 확인, 선택, 비활성화 및 기타 속성을 설정하거나 가져옵니다. prop()으로 구현할 수 있는 다른 작업의 경우 prop() 함수를 사용해 보세요.
아아아아위 내용은 예제와 사용법을 통해 jquery의 attr과 prop의 차이점에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

각각의 엔진의 구현 원리 및 최적화 전략이 다르기 때문에 JavaScript 엔진은 JavaScript 코드를 구문 분석하고 실행할 때 다른 영향을 미칩니다. 1. 어휘 분석 : 소스 코드를 어휘 단위로 변환합니다. 2. 문법 분석 : 추상 구문 트리를 생성합니다. 3. 최적화 및 컴파일 : JIT 컴파일러를 통해 기계 코드를 생성합니다. 4. 실행 : 기계 코드를 실행하십시오. V8 엔진은 즉각적인 컴파일 및 숨겨진 클래스를 통해 최적화하여 Spidermonkey는 유형 추론 시스템을 사용하여 동일한 코드에서 성능이 다른 성능을 제공합니다.

실제 세계에서 JavaScript의 응용 프로그램에는 서버 측 프로그래밍, 모바일 애플리케이션 개발 및 사물 인터넷 제어가 포함됩니다. 1. 서버 측 프로그래밍은 Node.js를 통해 실현되며 동시 요청 처리에 적합합니다. 2. 모바일 애플리케이션 개발은 재교육을 통해 수행되며 크로스 플랫폼 배포를 지원합니다. 3. Johnny-Five 라이브러리를 통한 IoT 장치 제어에 사용되며 하드웨어 상호 작용에 적합합니다.

일상적인 기술 도구를 사용하여 기능적 다중 테넌트 SaaS 응용 프로그램 (Edtech 앱)을 구축했으며 동일한 작업을 수행 할 수 있습니다. 먼저, 다중 테넌트 SaaS 응용 프로그램은 무엇입니까? 멀티 테넌트 SAAS 응용 프로그램은 노래에서 여러 고객에게 서비스를 제공 할 수 있습니다.

이 기사에서는 Contrim에 의해 확보 된 백엔드와의 프론트 엔드 통합을 보여 주며 Next.js를 사용하여 기능적인 Edtech SaaS 응용 프로그램을 구축합니다. Frontend는 UI 가시성을 제어하기 위해 사용자 권한을 가져오고 API가 역할 기반을 준수하도록합니다.

JavaScript는 현대 웹 개발의 핵심 언어이며 다양성과 유연성에 널리 사용됩니다. 1) 프론트 엔드 개발 : DOM 운영 및 최신 프레임 워크 (예 : React, Vue.js, Angular)를 통해 동적 웹 페이지 및 단일 페이지 응용 프로그램을 구축합니다. 2) 서버 측 개발 : Node.js는 비 차단 I/O 모델을 사용하여 높은 동시성 및 실시간 응용 프로그램을 처리합니다. 3) 모바일 및 데스크탑 애플리케이션 개발 : 크로스 플랫폼 개발은 개발 효율을 향상시키기 위해 반응 및 전자를 통해 실현됩니다.

JavaScript의 최신 트렌드에는 Typescript의 Rise, 현대 프레임 워크 및 라이브러리의 인기 및 WebAssembly의 적용이 포함됩니다. 향후 전망은보다 강력한 유형 시스템, 서버 측 JavaScript 개발, 인공 지능 및 기계 학습의 확장, IoT 및 Edge 컴퓨팅의 잠재력을 포함합니다.

JavaScript는 현대 웹 개발의 초석이며 주요 기능에는 이벤트 중심 프로그래밍, 동적 컨텐츠 생성 및 비동기 프로그래밍이 포함됩니다. 1) 이벤트 중심 프로그래밍을 사용하면 사용자 작업에 따라 웹 페이지가 동적으로 변경 될 수 있습니다. 2) 동적 컨텐츠 생성을 사용하면 조건에 따라 페이지 컨텐츠를 조정할 수 있습니다. 3) 비동기 프로그래밍은 사용자 인터페이스가 차단되지 않도록합니다. JavaScript는 웹 상호 작용, 단일 페이지 응용 프로그램 및 서버 측 개발에 널리 사용되며 사용자 경험 및 크로스 플랫폼 개발의 유연성을 크게 향상시킵니다.

Python은 데이터 과학 및 기계 학습에 더 적합한 반면 JavaScript는 프론트 엔드 및 풀 스택 개발에 더 적합합니다. 1. Python은 간결한 구문 및 풍부한 라이브러리 생태계로 유명하며 데이터 분석 및 웹 개발에 적합합니다. 2. JavaScript는 프론트 엔드 개발의 핵심입니다. Node.js는 서버 측 프로그래밍을 지원하며 풀 스택 개발에 적합합니다.


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

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

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.
