웹 프론트엔드 JS 튜토리얼 Vue.js_Others의 기본 지식 요약

Vue.js_Others의 기본 지식 요약

May 16, 2016 pm 03:03 PM
vue.js

소개

vue.js는 웹 애플리케이션 인터페이스를 구축하는 데 사용되는 라이브러리입니다

기술적으로 Vue.js는 뷰와 데이터 바인딩 모델을 두 가지 방식으로 연결하는 MVVM 패턴의 ViewModel 레이어에 중점을 둡니다. 실제 DOM 조작 및 출력 형식은 지시어 및 필터로 추상화됩니다

철학 분야에서는 MVVM 데이터 바인딩 API를 최대한 간단하게 만들어 보세요. 모듈성과 결합성 또한 중요한 설계 고려 사항이었습니다. Vue는 포괄적인 프레임워크가 아니며 간단하고 유연하게 설계되었습니다. 신속한 프로토타이핑에 사용하거나 다른 라이브러리와 혼합하여 프런트엔드 스택을 정의할 수 있습니다.

뷰. Node.js API는 AngularJS, KnockoutJS Ractive.js Rivets.js를 의미합니다. 유사성에도 불구하고 저는 Vue.js가 기존 프레임워크 중 일부를 절충할 수 있는 가치를 제공한다고 믿습니다

이미 일부 용어에 익숙하더라도 다음 Vue.js에서는 이러한 용어에 대한 개념이 다를 수 있으므로 다음 개념 개요를 살펴보는 것이 좋습니다.

개념개요

뷰모델

모델과 뷰를 동기화하는 개체입니다. Vue.js에서 ViewModel은 인스턴스화된 Vue 또는 해당 하위 클래스의 생성자입니다

var vm = new Vue({ /* options */ })
로그인 후 복사

이것은 Vue.js를 사용할 때 개발자로서 상호 작용하게 될 주요 개체입니다. 자세한 내용은 클래스: Vue를 참조하세요.

보기

사용자가 보는 실제 HTML/DOM

vm.$el // The View
로그인 후 복사


Vue.js를 사용하는 경우 사용자 정의 지침을 제외하고는 DOM 작업을 거의 건드리지 않습니다. 데이터가 업데이트되면 뷰 업데이트가 각 testNode 노드에 대해 매우 정확할 수 있습니다. 일괄 처리하고 비동기식으로 실행하여 더 나은 성능을 제공합니다.

모델

약간 변형된 자바스크립트 객체입니다

vm.$data // The Model
로그인 후 복사

Vue.js에서 모델은 단순한 Javascript 객체 및 데이터 객체일 뿐이며 해당 속성을 조작하고 모델을 보고 변경 사항을 관찰하고 알림을 받을 수 있습니다. Vue.js는 ES5 getter/setter를 사용하여 데이터 객체의 속성을 변환하므로 더티 검사 없이 직접 작업이 가능합니다.

데이터 개체는 적절한 경우 변경되므로 이를 수정하면 vm.$data를 참조로 수정하는 것과 동일한 효과가 있습니다. 이는 또한 여러 ViewModel 인스턴스가 동일한 데이터 조각을 관찰하는 것을 용이하게 합니다.

기술적인 세부정보는 인스턴스화 옵션: 데이터를 참조하세요.

지시문

비공개 HTML 속성은 Vue.js에 DOM에서 일부 처리를 수행하도록 지시합니다

<div v-text="message"></div>
로그인 후 복사

여기서 div 요소에는 v-text 지시어가 있으며 값은 message입니다. 이는 Vue.js에 이 div 노드의 콘텐츠를 viewMode의 메시지 속성과 동기화되도록 지시하는 것을 의미합니다.

지시문은 모든 DOM 작업을 캡슐화할 수 있습니다. 예를 들어 v-attr은 속성 요소를 작동하고, v-repeat는 배열을 기반으로 요소를 복제하며, v-on은 이벤트 모니터링을 연결합니다.

콧수염 바인딩

텍스트와 속성 모두에서 콧수염 스타일 바인딩을 사용할 수도 있습니다. 이는 v-text v-attr 지시문으로 변환됩니다. 예:

<div id="person-{{id}}">Hello {{name}}!</div>
로그인 후 복사

편리하지만 주의해야 할 사항이 몇 가지 있습니다.

이미지의 src 속성을 설정하면 HTTP 요청이 전송되기 때문에 처음 템플릿을 파싱하여 404가 나타날 때는 v-attr을 사용하는 것이 좋습니다

Internet Explorer는 HTML을 구문 분석할 때 유효하지 않은 내부 스타일 속성을 제거하므로 IE 바인딩 인라인 CSS를 지원하려면 항상 v-style을 사용합니다

v-html 내에서 세 개의 중괄호 {{{like this}}}를 사용하여 이스케이프되지 않은 HTML을 처리할 수 있지만 잠재적인 XSS 공격이 있을 수 있고 창을 열 수도 있으므로 절대적으로 안전하도록 권장됩니다. 데이터가 완료되면 사용자 정의 파이프라인 필터를 통해 신뢰할 수 없는 HTML을 정리합니다.

필터

뷰를 업데이트하기 전에 함수를 사용하여 이 원시 데이터를 처리할 수 있습니다. "파이프라인" 지시문이나 바인딩을 사용하고 있습니다.

<div>{{message | capitalize}}</div>
로그인 후 복사

이제 div의 텍스트 콘텐츠가 업데이트되기 전에 이 메시지의 값이 대문자화 기능에 의해 처리됩니다. 자세한 내용은 심층 필터를 참조하세요.

구성품

Vue.js에서 컴포넌트는 Vue.comComponent(ID, 생성자)를 통해 등록되는 간단한 뷰 모델 생성자입니다. 다른 뷰 모델 템플릿의 v-Component 지시문은 연관된 ID를 통해 중첩될 수 있습니다. 이 간단한 메커니즘을 사용하면 최신 브라우저나 강력한 폴리필 없이도 선언적 뷰 모델을 웹 구성 요소와 유사한 방식으로 재사용하고 구성할 수 있습니다. 애플리케이션을 더 작은 구성 요소로 분할함으로써 결과적으로 고도로 분리되고 유지 관리가 가능한 코드 기반이 탄생합니다. 자세한 내용은 ViewModel 구성을 참조하세요.

빠른 예

<div id="demo">
  <h1>{{title | uppercase}}</h1>
  <ul>
    <li
      v-repeat="todos"
      v-on="click: done = !done"
      class="{{done &#63; 'done' : ''}}">
      {{content}}
    </li>
  </ul>
</div>
로그인 후 복사
 
var demo = new Vue({
  el: '#demo',
  data: {
    title: 'todos',
    todos: [
      {
        done: true,
        content: 'Learn JavaScript'
      },
      {
        done: false,
        content: 'Learn vue.js'
      }
    ]
  }
})

로그인 후 복사

대략적인 번역이니 오류 지적해주세요

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

vite가 .env 파일을 구문 분석하는 방법에 대한 심층 토론 vite가 .env 파일을 구문 분석하는 방법에 대한 심층 토론 Jan 24, 2023 am 05:30 AM

Vue 프레임워크를 사용하여 프런트엔드 프로젝트를 개발할 때 배포 시 여러 환경을 배포하게 되는데, 개발 환경, 테스트 환경, 온라인 환경에서 호출되는 인터페이스 도메인 이름이 다른 경우가 많습니다. 어떻게 구별할 수 있나요? 그것은 환경 변수와 패턴을 사용하는 것입니다.

Vue 프로젝트에 Ace 코드 편집기를 통합하는 방법에 대한 자세한 그래픽 설명 Vue 프로젝트에 Ace 코드 편집기를 통합하는 방법에 대한 자세한 그래픽 설명 Apr 24, 2023 am 10:52 AM

Ace는 JavaScript로 작성된 내장형 코드 편집기입니다. Sublime, Vim 및 TextMate와 같은 기본 편집기의 기능 및 성능과 일치합니다. 모든 웹페이지와 JavaScript 애플리케이션에 쉽게 삽입할 수 있습니다. Ace는 Cloud9 IDE의 메인 편집자로 유지되며 Mozilla Skywriter(Bespin) 프로젝트의 후속 버전입니다.

vue에서 구성 요소화와 모듈화의 차이점은 무엇입니까 vue에서 구성 요소화와 모듈화의 차이점은 무엇입니까 Dec 15, 2022 pm 12:54 PM

구성요소화와 모듈화의 차이점: 모듈화는 코드 논리의 관점에서 구분되며, 코드 계층 개발을 용이하게 하고 각 기능 모듈의 기능이 일관되게 유지되도록 합니다. 컴포넌트화는 UI 인터페이스 관점에서 계획하는 것으로 프런트엔드의 컴포넌트화는 UI 컴포넌트의 재사용을 용이하게 합니다.

Vue3에서 단위 테스트를 작성하는 방법 살펴보기 Vue3에서 단위 테스트를 작성하는 방법 살펴보기 Apr 25, 2023 pm 07:41 PM

Vue.js는 오늘날 프런트엔드 개발에서 매우 인기 있는 프레임워크가 되었습니다. Vue.js가 계속 발전함에 따라 단위 테스트는 점점 더 중요해지고 있습니다. 오늘은 Vue.js 3에서 단위 테스트를 작성하는 방법을 살펴보고 몇 가지 모범 사례와 일반적인 문제 및 솔루션을 제공하겠습니다.

vue3의 반응성()에 대해 자세히 이야기해 봅시다. vue3의 반응성()에 대해 자세히 이야기해 봅시다. Jan 06, 2023 pm 09:21 PM

서문: vue3 개발에서 반응형은 반응형 데이터를 구현하는 방법을 제공합니다. 일상적인 개발에서 자주 사용되는 API입니다. 이 기사에서 저자는 내부 작동 메커니즘을 탐구합니다.

Vue의 JSX 구문과 템플릿 구문의 간단한 비교(장단점 분석) Vue의 JSX 구문과 템플릿 구문의 간단한 비교(장단점 분석) Mar 23, 2023 pm 07:53 PM

Vue.js에서 개발자는 JSX 구문과 템플릿 구문이라는 두 가지 다른 구문을 사용하여 사용자 인터페이스를 만들 수 있습니다. 두 구문 모두 장점과 단점이 있습니다. 차이점, 장점 및 단점을 논의해 보겠습니다.

Vue3 동적 구성 요소에서 예외를 처리하는 방법에 대한 간략한 분석 Vue3 동적 구성 요소에서 예외를 처리하는 방법에 대한 간략한 분석 Dec 02, 2022 pm 09:11 PM

Vue3 동적 구성 요소에서 예외를 처리하는 방법은 무엇입니까? 다음 기사에서는 Vue3 동적 구성 요소 예외 처리 방법에 대해 설명합니다. 이것이 모든 사람에게 도움이 되기를 바랍니다.

Vue2의 Composition API 구현 원리 분석 Vue2의 Composition API 구현 원리 분석 Jan 13, 2023 am 08:30 AM

Vue3 출시 이후, 단어 구성 API는 Vue를 작성하는 학생들의 시야에 들어왔습니다. 이제 @의 출시로 인해 구성 API가 이전 옵션 API보다 얼마나 나은지 항상 들어보셨을 것입니다. vue/composition-api 플러그인, Vue2 학생들도 버스에 탑승할 수 있습니다. 다음으로 우리는 주로 반응형 참조와 반응형을 사용하여 이 플러그인이 이를 어떻게 달성하는지에 대한 심층 분석을 수행할 것입니다.

See all articles