Vue에서 전역 로딩 효과를 구현하는 방법
프런트 엔드 개발에서는 사용자가 웹 페이지와 상호 작용하는 동안 데이터가 로드될 때까지 기다려야 하는 경우가 종종 있습니다. 이때 일반적으로 사용자에게 기다리도록 상기시키는 로딩 효과가 표시됩니다. Vue 프레임워크에서는 전역 로딩 효과를 구현하는 방법이 어렵지 않습니다.
1단계: Vue 플러그인 만들기
모든 Vue 인스턴스에서 참조할 수 있는 loading
이라는 Vue 플러그인을 만들 수 있습니다. 플러그인에서는 다음 두 가지 메소드를 구현해야 합니다: loading
的Vue插件,该插件可以在所有的Vue实例中引用。在插件中,我们需要实现以下两个方法:
-
show()
:用于显示loading效果 -
hide()
:用于隐藏loading效果
以下是loading
插件的代码:
const Loading = { show() { // 显示loading效果的代码 }, hide() { // 隐藏loading效果的代码 } } export default { install(Vue) { Vue.prototype.$loading = Loading } }
在上述代码中,我们定义了一个名为Loading
的对象,该对象包含了显示和隐藏loading效果的方法。install()
方法被用于将loading
对象安装到Vue实例上,从而使该对象在所有Vue实例中可以被引用。
第二步:实现loading组件
为了实现loading效果,我们需要在Vue组件中添加一个覆盖整个屏幕的loading层。这可以通过CSS来实现。具体来说,我们可以在Vue组件内动态添加和删除loading层的DOM元素,从而实现loading效果的显示和隐藏。以下是一个简单的loading组件:
<template> <div v-if="visible" class="loading-mask"> <div class="loading-spinner"></div> </div> </template> <script> export default { data() { return { visible: false } }, methods: { show() { this.visible = true }, hide() { this.visible = false } } } </script> <style> .loading-mask { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background-color: rgba(0, 0, 0, 0.5); z-index: 999; display: flex; align-items: center; justify-content: center; } .loading-spinner { border: 4px solid #f3f3f3; border-radius: 50%; border-top: 4px solid #3498db; width: 60px; height: 60px; -webkit-animation: spin 2s linear infinite; animation: spin 2s linear infinite; } @-webkit-keyframes spin { 0% { -webkit-transform: rotate(0deg); } 100% { -webkit-transform: rotate(360deg); } } @keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } } </style>
在上述代码中,我们定义了一个名为loading-mask
的div层,它覆盖整个页面,并设置了一个半透明的黑色背景。在loading-mask
中,我们添加了另一个名为loading-spinner
的div层,该层用于显示一个旋转的loading图标。最后,我们在Vue组件的data
中定义了一个visible
变量,用于判断loading层是否需要显示。
第三步:在组件中使用loading
现在我们已经实现了一个基本的loading组件和一个Vue插件,接下来我们需要在Vue组件中使用它们。
首先,在Vue组件中引入刚才创建的Vue插件,并把loading组件添加到当前组件中:
<template> <div> <h1>这是一个Vue组件</h1> <loading ref="loading"></loading> </div> </template> <script> import LoadingPlugin from '@/plugins/loading' import Loading from '@/components/Loading' export default { name: 'HelloWorld', components: { Loading }, mounted() { this.$loading = this.$refs.loading }, plugins: [ LoadingPlugin ], methods: { fetchData() { this.$loading.show() // 显示loading效果 // 发送请求 // ... this.$loading.hide() // 隐藏loading效果 } } } </script>
在上述代码中,我们首先引入了之前创建的Vue插件LoadingPlugin
,然后使用components
属性将loading组件添加到当前组件中。在mounted()
方法中,我们将loading组件的实例赋值给$loading
属性,从而方便我们在当前组件中调用show和hide方法来显示和隐藏loading效果。
最后,在fetchData()方法中,我们可以调用this.$loading.show()
来显示loading效果,在数据加载完毕后,再调用this.$loading.hide()
方法来隐藏它。这样我们就成功地实现了一个全局loading效果。
总结
在本文中,我们介绍了如何在Vue框架中实现一个全局loading效果。我们创建了一个loading
-
show()
: 로딩 효과를 표시하는 데 사용됨 hide ()
코드>: 로딩 효과를 숨기는 데 사용
로딩
플러그인의 코드입니다: 🎜rrreee🎜위 코드에서 , 로딩 효과를 표시하고 숨기기 위한 메서드가 포함된 Loading 개체라는 파일을 정의합니다. <code>install()
메소드는 모든 Vue 인스턴스에서 해당 객체를 참조할 수 있도록 Vue 인스턴스에 loading
객체를 설치하는 데 사용됩니다. 🎜🎜2단계: 로딩 컴포넌트 구현🎜🎜로딩 효과를 얻으려면 Vue 컴포넌트에 전체 화면을 덮는 로딩 레이어를 추가해야 합니다. 이는 CSS를 통해 달성할 수 있습니다. 특히 Vue 구성 요소 내 로딩 레이어의 DOM 요소를 동적으로 추가 및 삭제하여 로딩 효과를 표시하고 숨길 수 있습니다. 다음은 간단한 로딩 구성 요소입니다. 🎜rrreee🎜위 코드에서는 전체 페이지를 덮고 반투명 검정색 배경을 설정하는 loading-mask
라는 div 레이어를 정의합니다. loading-mask
에서는 회전하는 로딩 아이콘을 표시하는 데 사용되는 loading-spinner
라는 또 다른 div 레이어를 추가했습니다. 마지막으로, 로딩 레이어를 표시해야 하는지 여부를 결정하기 위해 Vue 구성 요소의 data
에 visible
변수를 정의했습니다. 🎜🎜3단계: 컴포넌트에서 로딩 사용🎜🎜이제 기본 로딩 컴포넌트와 Vue 플러그인을 구현했으므로 Vue 컴포넌트에서 이를 사용해야 합니다. 🎜🎜먼저 Vue 컴포넌트에 방금 생성한 Vue 플러그인을 도입하고 현재 컴포넌트에 로딩 컴포넌트를 추가합니다. 🎜rrreee🎜위 코드에서는 먼저 Vue 플러그인 LoadingPlugin
을 도입합니다. > 이전에 생성된 다음 composites
속성을 사용하여 현재 구성 요소에 로드 구성 요소를 추가합니다. mounted()
메소드에서는 로딩 구성 요소의 인스턴스를 $loading
속성에 할당합니다. 이를 통해 현재 구성 요소의 show 및 hide 메소드를 쉽게 호출할 수 있습니다. 로딩 효과를 표시하고 숨깁니다. 🎜🎜마지막으로 fetchData() 메서드에서 this.$loading.show()
를 호출하여 로딩 효과를 표시할 수 있습니다. 데이터가 로드된 후 this.$loading을 호출하세요. hide()
메소드를 사용하여 숨깁니다. 이러한 방식으로 우리는 전역 로딩 효과를 성공적으로 달성했습니다. 🎜🎜요약🎜🎜이 글에서는 Vue 프레임워크에서 글로벌 로딩 효과를 구현하는 방법을 소개했습니다. 로딩
플러그인을 생성하여 모든 Vue 구성 요소에서 호출할 수 있도록 Vue 인스턴스에 설치합니다. 또한 DOM 요소를 동적으로 추가 및 삭제하여 로딩 효과를 표시하고 숨기는 로딩 구성 요소를 구현했습니다. 마지막으로 Vue 컴포넌트에서 $loading 객체의 show 및 hide 메소드를 호출하여 로딩 효과를 표시하고 숨깁니다. 이 구현을 통해 우리는 좋은 사용자 경험을 달성하고, 사용자 대기 시간을 줄이고, 애플리케이션 성능을 향상시킬 수 있습니다. 🎜위 내용은 Vue에서 전역 로딩 효과를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











vue.js의 시계 옵션을 사용하면 개발자가 특정 데이터의 변경 사항을들을 수 있습니다. 데이터가 변경되면 콜백 기능을 트리거하여 업데이트보기 또는 기타 작업을 수행합니다. 구성 옵션에는 즉시 콜백을 실행할지 여부와 DEEP를 지정하는 즉시 포함되며, 이는 객체 또는 어레이에 대한 변경 사항을 재귀 적으로 듣는 지 여부를 지정합니다.

vue.js에서 JS 파일을 참조하는 세 가지 방법이 있습니다. & lt; script & gt; 꼬리표;; mounted () 라이프 사이클 후크를 사용한 동적 가져 오기; Vuex State Management Library를 통해 수입.

vue.js에서 bootstrap 사용은 5 단계로 나뉩니다 : Bootstrap 설치. main.js.의 부트 스트랩 가져 오기 부트 스트랩 구성 요소를 템플릿에서 직접 사용하십시오. 선택 사항 : 사용자 정의 스타일. 선택 사항 : 플러그인을 사용하십시오.

HTML 템플릿의 버튼을 메소드에 바인딩하여 VUE 버튼에 함수를 추가 할 수 있습니다. 메소드를 정의하고 VUE 인스턴스에서 기능 로직을 작성하십시오.

CSS 애니메이션 또는 타사 라이브러리를 사용하여 VUE에서 Marquee/Text Scrolling Effects를 구현하십시오. 이 기사는 CSS 애니메이션 사용 방법을 소개합니다. & lt; div & gt; CSS 애니메이션을 정의하고 오버플로를 설정하십시오 : 숨겨진, 너비 및 애니메이션. 키 프레임을 정의하고 변환을 설정하십시오 : Translatex () 애니메이션의 시작과 끝에서. 지속 시간, 스크롤 속도 및 방향과 같은 애니메이션 속성을 조정하십시오.

vue.js는 이전 페이지로 돌아갈 수있는 네 가지 방법이 있습니다. $ router.go (-1) $ router.back () 사용 & lt; router-link to = & quot;/quot; Component Window.history.back () 및 메소드 선택은 장면에 따라 다릅니다.

vue.js에서 게으른 로딩을 사용하면 필요에 따라 부품 또는 리소스를 동적으로로드 할 수 있으므로 초기 페이지로드 시간을 줄이고 성능을 향상시킵니다. 특정 구현 방법에는 & lt; keep-alive & gt를 사용하는 것이 포함됩니다. & lt; 구성 요소는 & gt; 구성 요소. 게으른 하중은 FOUC (Splash Screen) 문제를 일으킬 수 있으며 불필요한 성능 오버 헤드를 피하기 위해 게으른 하중이 필요한 구성 요소에만 사용해야합니다.

Vue DevTools를 사용하여 브라우저 콘솔에서 vue 탭을 보면 VUE 버전을 쿼리 할 수 있습니다. npm을 사용하여 "npm list -g vue"명령을 실행하십시오. package.json 파일의 "종속성"객체에서 vue 항목을 찾으십시오. Vue Cli 프로젝트의 경우 "vue -version"명령을 실행하십시오. & lt; script & gt에서 버전 정보를 확인하십시오. vue 파일을 나타내는 html 파일의 태그.
