이 기사에서는 Vue3의 세 가지 새로운 기능인 Fragment(조각화된 노드), Suspense(비동기 구성 요소) 및 Portal(포털)을 안내합니다.
Vue3은 개발자에게 상처를 준 vue2의 비판을 해결하기 위해 몇 가지 새로운 기능을 추가했습니다. 동시에 vue2의 성능도 최적화되었습니다. 이 글에서는 vue3의 새로운 Fragment
, Teleport
및 Suspense
를 사용하는 방법을 살펴보겠습니다. Fragment
、Teleport
和Suspense
的使用方法。
Fragment
(碎片化节点)
不知道各位有没有在vue2中遇到过下图中的报错信息:
这是vue2
抛出的错误提示。意思是说组件只能有一个根元素。当我们新建一个vue页面时,通常会有多个不同的元素节点。我们会在最外层包裹一个div
来使其让它成为这个页面的根节点。但这并不友好。有时候我们并不需要这个div
元素。
vue3中解决了这个问题。vue3中新增了一个类似dom的标签元素<fragment></fragment>
。如果在vue页面中有多个元素节点。那么编译时vue会在这些元素节点上添加一个<fragment></fragment>
标签。并且该标签不会出现在dom树中。
Suspense
(异步组件)
vue3中提供一个<suspense></suspense>
组件用于控制异步组件。
//创建一个异步组件 <script> const { createApp,defineAsyncComponent } = Vue const app = createApp({}) const AsyncComp = defineAsyncComponent( () => new Promise((resolve, reject) => { setTimeout(() => resolve({ template: '<div>I am async!</div>' }),3000) }) ) app.component('async-component', AsyncComp) app.mount('#app') </script>
用Suspense
包裹异步组件 async-component
<Suspense> <template #default> <async-component /> </template> <template #fallback> Loading ... </template> </Suspense>
上面的异步组件使用了定时器,3秒后显示该组件 我们可以通过defineAsyncComponent
提供一系列的参数来定义异步组件
import { defineAsyncComponent } from 'vue' const AsyncComp = defineAsyncComponent({ // 工厂函数 loader: () => import('./Foo.vue'), // 加载异步组件时要使用的组件 loadingComponent: LoadingComponent, // 加载失败时要使用的组件 errorComponent: ErrorComponent, // 在显示 loadingComponent 之前的延迟 | 默认值:200(单位 ms) delay: 200, // 如果提供了 timeout ,并且加载组件的时间超过了设定值,将显示错误组件 // 默认值:Infinity(即永不超时,单位 ms) timeout: 3000, // 定义组件是否可挂起 | 默认值:true suspensible: false, /** * * @param {*} error 错误信息对象 * @param {*} retry 一个函数,用于指示当 promise 加载器 reject 时,加载器是否应该重试 * @param {*} fail 一个函数,指示加载程序结束退出 * @param {*} attempts 允许的最大重试次数 */ onError(error, retry, fail, attempts) { if (error.message.match(/fetch/) && attempts <= 3) { // 请求发生错误时重试,最多可尝试 3 次 retry() } else { // 注意,retry/fail 就像 promise 的 resolve/reject 一样: // 必须调用其中一个才能继续错误处理。 fail() } } })
当配置项中的suspensible为true时,被Suspense
包裹的异步组件将会被控制
Portal
(传送门)
在vue2中我们可能会使用例如element-ui,iview等组件库,有时候我们会发现这些ui组件库中的某些组件渲染层级并不包含在vue dom中。如 modal toast等组件的层级就在vue dom 之外。这种在vue之外的层级方便我们进行全局处理和管理。vue3中提供一对<teleport></teleport>
用于移动dom的层级
<div id="app"> <h1 id="Hello-nbsp-Async-nbsp-Component">Hello Async Component</h1> <com-a /> </div> <div class="i-can-fly"></div> // 组件a const { createApp } = Vue const componentA = { template: `<com-b><com-b/><div class="i-can-fly">我能瞬间移动</div>` } const componentB ={ template: `<div class="i-can-fly">我能飞</div>` } const app = createApp({}) app.component('com-b',componentB) app.component('com-a',componentA) app.mount('#app')
此时我们打开控制台查看元素
渲染的结果如下。然后我们修改代码添加teleport
标签
<div id="app"> <----...---> <teleport to=".i-can-fly"> <com-a /> </teleport> </div> <div class="i-can-fly"></div>
此时我们发现组件B已经不在app中了。而是出现在了以类选择器为i-can-fly
的div中。
值得注意的是 teleport
Fragment
(조각화된 노드)
vue2에서 아래 그림의 오류 메시지가 표시되었는지 모르겠습니다. 이것은 vue2
에서 발생한 오류 메시지입니다. 이는 구성 요소가 루트 요소를 하나만 가질 수 있음을 의미합니다. 새로운 vue 페이지를 생성할 때 일반적으로 여러 개의 서로 다른 요소 노드가 있습니다. 가장 바깥쪽 레이어에 div
를 래핑하여 페이지의 루트 노드로 만듭니다. 그러나 이것은 우호적이지 않습니다. 때로는 이 div
요소가 필요하지 않을 때도 있습니다. 🎜🎜이 문제는 vue3에서 해결되었습니다. 새로운 돔형 태그 요소 <fragment></fragment>
가 vue3에 추가되었습니다. Vue 페이지에 요소 노드가 여러 개 있는 경우. 그런 다음 vue는 컴파일할 때 이러한 요소 노드에 <fragment></fragment>
태그를 추가합니다. 그리고 태그는 DOM 트리에 나타나지 않습니다. 🎜🎜
Suspense
(비동기 구성 요소)
🎜vue3은 비동기 제어를 위한 <suspense></suspense>
구성 요소를 제공합니다. 구성 요소. 🎜rrreee🎜Suspense
를 사용하여 비동기 구성 요소 async-comComponent
를 래핑합니다.🎜rrreee🎜위의 비동기 구성 요소는 타이머를 사용하여 3초 후에 구성 요소를 표시합니다. code>defineAsyncComponent 비동기 구성 요소를 정의하기 위한 일련의 매개 변수를 제공합니다🎜rrreee🎜구성 항목에서 suspensible이 true인 경우 Suspense
로 래핑된 비동기 구성 요소가 제어됩니다🎜
포털
(포털)
🎜vue2에서는 element-ui, iview 등과 같은 구성 요소 라이브러리를 사용할 수 있습니다. 때로는 이러한 UI 구성 요소 라이브러리에서 이를 찾을 수 있습니다. 일부 구성 요소 렌더링 수준은 vue dom에 포함되지 않습니다. 모달 토스트와 같은 구성 요소의 계층 구조는 vue dom 외부에 있습니다. vue 외부의 이 수준은 글로벌 처리 및 관리를 용이하게 합니다. Vue3는 DOM 레벨을 이동하기 위해 한 쌍의 <teleport></teleport>
를 제공합니다🎜rrreee🎜이제 요소를 보기 위해 콘솔을 엽니다🎜🎜teleport
태그를 추가합니다🎜rrreee🎜이 때 구성 요소 B가 더 이상 앱에 없는 것을 발견했습니다. 대신 클래스 선택기 i-can-fly
가 있는 div에 표시됩니다. 🎜🎜teleport
태그의 to 매개변수는 패키지 콘텐츠가 이동될 위치를 나타냅니다. 🎜🎜【관련 추천: 🎜vue.js tutorial🎜】🎜위 내용은 Vue3의 Fragment, Suspense 및 Portal 기능을 빠르게 이해하세요.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

vue.js는 여러 기능을 통해 사용자 경험을 향상시킵니다. 1. 응답 시스템은 실시간 데이터 피드백을 실현합니다. 2. 구성 요소 개발은 코드 재사용 성을 향상시킵니다. 3. Vuerouter는 원활한 내비게이션을 제공합니다. 4. 동적 데이터 바인딩 및 전환 애니메이션은 상호 작용 효과를 향상시킵니다. 5. 오류 처리 메커니즘은 사용자 피드백을 보장합니다. 6. 성능 최적화 및 모범 사례는 응용 프로그램 성능을 향상시킵니다.

웹 개발에서 vue.js의 역할은 개발 프로세스를 단순화하고 효율성을 향상시키는 점진적인 JavaScript 프레임 워크 역할을하는 것입니다. 1) 개발자는 반응 형 데이터 바인딩 및 구성 요소 개발을 통해 비즈니스 로직에 집중할 수 있습니다. 2) vue.js의 작동 원리는 반응 형 시스템 및 가상 DOM에 의존하여 성능을 최적화합니다. 3) 실제 프로젝트에서는 Vuex를 사용하여 글로벌 상태를 관리하고 데이터 대응 성을 최적화하는 것이 일반적입니다.

vue.js는 2014 년 Yuxi가 출시하여 사용자 인터페이스를 구축하기 위해 진보적 인 JavaScript 프레임 워크입니다. 핵심 장점은 다음과 같습니다. 1. 응답 데이터 바인딩, 데이터 변경의 자동 업데이트보기; 2. 구성 요소 개발, UI는 독립적이고 재사용 가능한 구성 요소로 분할 될 수 있습니다.

Netflix는 React를 프론트 엔드 프레임 워크로 사용합니다. 1) React의 구성 요소화 된 개발 모델과 강력한 생태계가 Netflix가 선택한 주된 이유입니다. 2) 구성 요소화를 통해 Netflix는 복잡한 인터페이스를 비디오 플레이어, 권장 목록 및 사용자 댓글과 같은 관리 가능한 청크로 분할합니다. 3) React의 가상 DOM 및 구성 요소 수명주기는 렌더링 효율성 및 사용자 상호 작용 관리를 최적화합니다.

프론트 엔드 기술에서 Netflix의 선택은 주로 성능 최적화, 확장 성 및 사용자 경험의 세 가지 측면에 중점을 둡니다. 1. 성능 최적화 : Netflix는 React를 주요 프레임 워크로 선택하고 Speedcurve 및 Boomerang과 같은 도구를 개발하여 사용자 경험을 모니터링하고 최적화했습니다. 2. 확장 성 : 마이크로 프론트 엔드 아키텍처를 채택하여 응용 프로그램을 독립 모듈로 분할하여 개발 효율성 및 시스템 확장 성을 향상시킵니다. 3. 사용자 경험 : Netflix는 재료 -UI 구성 요소 라이브러리를 사용하여 A/B 테스트 및 사용자 피드백을 통해 인터페이스를 지속적으로 최적화하여 일관성과 미학을 보장합니다.

NetflixusesAcustomFrameworkCalled "Gibbon"BuiltonReact, NotreactorVuedirectly.1) TeamExperience : 2) ProjectComplexity : vueforsimplerProjects, 3) CustomizationNeeds : reactoffersmoreflex.4)

Netflix는 주로 프레임 워크 선택의 성능, 확장 성, 개발 효율성, 생태계, 기술 부채 및 유지 보수 비용을 고려합니다. 1. 성능 및 확장 성 : Java 및 SpringBoot는 대규모 데이터 및 높은 동시 요청을 효율적으로 처리하기 위해 선택됩니다. 2. 개발 효율성 및 생태계 : React를 사용하여 프론트 엔드 개발 효율성을 향상시키고 풍부한 생태계를 활용하십시오. 3. 기술 부채 및 유지 보수 비용 : Node.js를 선택하여 유지 보수 비용과 기술 부채를 줄이기 위해 마이크로 서비스를 구축하십시오.

Netflix는 주로 VUE가 특정 기능을 위해 보충하는 프론트 엔드 프레임 워크로 React를 사용합니다. 1) React의 구성 요소화 및 가상 DOM은 Netflix 애플리케이션의 성능 및 개발 효율을 향상시킵니다. 2) VUE는 Netflix의 내부 도구 및 소규모 프로젝트에 사용되며 유연성과 사용 편의성이 핵심입니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

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

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

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