Vue 단일 파일의 참조 경로에 대한 방법은 무엇입니까?
이 글에서는 Vue 단일 파일의 참조 경로 처리에 대한 관련 정보를 주로 소개합니다. 이 글에서는 vue.js를 배우고 사용하는 모든 사람이 참조할 수 있는 학습 가치가 있습니다. 따라올 수 있습니다. 와서 저와 함께 배우세요.
Foreword
Vue의 단일 파일 구성 요소는 Vue를 사용할 때 매우 일반적으로 사용됩니다. Vue 단일 파일 개발 프로세스 중에 파일 경로 처리는 , 배경 스타일 처리 등 다음은 다양한 시나리오에서
의 src 처리에 대해 설명하고 vue+webpack을 사용하여 개발 프로세스 중에 정적 리소스(예: 이미지 처리)를 올바르게 참조하는 방법을 설명합니다.
아래에 표시된 것처럼 다양한 시나리오에서 이미지 경로를 참조하는 예는 아래 단일 파일 구성 요소에 제공됩니다(이미지 정적 리소스는 src/assets/small.png에 저장됨).
<template> <p id="app"> <!-- 1. 模版中src选项直接写相对路径 --> <img src="./assets/small.png" alt="图片相对路径测试"> <!-- 2. 模版中src选项绑定相对路径字符串 --> <img :src="relative_img" alt="图片相对路径测试"> <!-- 3. 模版中src选项绑定html绝对路径字符串 --> <img :src="absolute_img" alt="图片绝对路径测试"> <!-- 4. 模版中src选项绑定手动加载的图片资源 --> <img :src="smallImg" alt="图片资源测试"> </p> </template> <script> import smallImg from './assets/small.png'; export default { name: 'app', data() { return { smallImg: smallImg, relative_img: './assets/small.png', absolute_img: '/static/img/small.png', }; }, } </script>
위의 코드 조각은 4가지 유형을 제공합니다. 시나리오에서는 img 태그를 사용하여 Vue 단일 파일 구성 요소의 이미지 리소스를 참조합니다. 물론 이 네 가지 방법 모두가 이미지 리소스를 올바르게 로드할 수 있는 것은 아닙니다.
시나리오 1:
템플릿의 상대 경로를 사용하여 src 속성에 직접 바인딩하면 이미지 리소스를 올바르게 로드할 수 있습니다. 우리는 웹팩이 vue 단일 파일 구성요소를 처리하는 과정에서 vue-loader가 주로 *.vue 파일 처리를 담당한다는 것을 알고 있습니다. vue-loader 문서의 vue-loader 리소스 경로 처리 섹션에서는 vue-loader가 템플릿에서 리소스 경로를 처리하는 방법을 설명합니다. 예: , background: url(), @import 등은 모듈 종속성으로 처리됩니다. 즉, 이러한 경우 vue-loader는 경로의 리소스 참조와 최종 경로 교체를 자동으로 처리합니다. img 처리는 다음과 같습니다.
<img src="./logo.png">
는 vue 템플릿 컴파일러에 의해 다음과 같이 컴파일됩니다.
createElement('img', { attrs: { src: require('./logo.png') }})
이것은 또한 vue-loader가 자동으로 리소스 및 경로 가져오기를 도와주기 때문에 사례 1에서 이미지 콘텐츠가 올바르게 표시될 수 있는 이유를 설명합니다. 교체 문제.
사례 2:
상대 경로 문자열 변수가 템플릿의 src 속성에 바인딩되어 있으면 이미지가 정상적으로 표시되지 않습니다. 그 이유는 vue-loader가 변수가 경로 문자열인지 식별할 수 없기 때문에 vue-loader가 자동으로 리소스를 도입하고 경로 교체를 하는 데에는 문제가 없습니다. 이 경우 컴파일된 템플릿은 여전히 상대 경로 문자열입니다. 분명히 해당 리소스 소개와 잘못된 경로가 없으면 이미지가 올바르게 표시될 수 없습니다.
상황 3:
상대 경로를 올바르게 표시할 수 없는 경우 많은 사람들이 절대 경로 변수를 사용하여 이미지를 가져오려고 합니다. 분명히 이 경우 이미지 리소스를 수동으로 가져오지 않았기 때문에 이미지를 표시할 수 없습니다. 참고: 많은 학생들이 리소스를 수동으로 도입한 다음 절대 경로 변수에 따라 src를 바인딩하려고 시도합니다. 실제로 dist/static/img/ 경로 아래에 참조된 리소스가 있지만 vue-cli 웹팩 템플릿의 url-loader가 있음을 발견합니다. img 유형 파일에서는 작동하지 않습니다. 로드 시 해시 값 처리가 추가됩니다. 이 경우 절대 경로 변수를 바인딩하더라도 해시 값이 추가된 이미지 파일과 정확하게 일치하지 않기 때문에 이미지를 올바르게 참조할 수 없습니다. 이미지를 수동으로 도입해야 하는 경우 상황 4에 대한 접근 방식이 권장됩니다.
사례 4:
템플릿에서 src 속성은 수동으로 도입된 이미지 리소스에 직접 바인딩됩니다. 이 경우 이미지가 올바르게 표시될 수 있습니다. 이 방법은 자동으로 가져온 경로에 해당하는 리소스를 처리할 때 vue-loader에서도 사용됩니다.
요약하자면, vue 단일 파일 구성 요소에서 이미지를 올바르게 표시하는 열쇠는 다음과 같습니다.
이미지 리소스가 필요하거나 가져온 경우 webpack의 url-loader에 의해 최종 디렉터리로 처리됩니다
img src 속성을 최종 이미지 리소스 경로로 바꿔야 합니다
위의 두 가지 사항은 필수입니다. Case 1과 Case 4에서 그림이 올바르게 표시될 수 있는 이유는 두 경우 모두 위의 두 가지 조건이 충족되기 때문입니다. 첫 번째 경우에는 vue-loader가 자동으로 이 작업을 수행했고, 네 번째 경우에는 수동으로 수행했습니다.
개발 중에 발생할 수 있는 문제:
개발 중에 그림 목록이 루프로 렌더링되는 시나리오가 발생할 수 있습니다. 위의 요약을 기반으로 그림 정보 개체의 배열을 구성할 수 있습니다. 예:
<template> <p id="app"> <!-- 1. 模版中 src 选项直接写相对路径 --> <img src="./assets/small.png" alt="图片相对路径测试"> <!-- 2. 模版中 src 选项绑定相对路径字符串 --> <img :src="relative_img" alt="图片相对路径测试"> <!-- 3. 模版中 src 选项绑定绝对路径字符串 --> <img :src="absolute_img" alt="图片绝对路径测试"> <!-- 4. 模版中 src 选项绑定手动加载的图片资源 --> <img :src="smallImg" alt="图片测试"> <!-- 5. 循环加载图片资源示例 --> <img v-for="image in imgList" :key="image.id" :src="image.src" :alt="image.title"> </p> </template> <script> import smallImg from './assets/small.png'; import bigImg from './assets/big.jpg'; export default { name: 'app', data() { return { smallImg: smallImg, relative_img: './assets/small.png', absolute_img: '/static/img/small.png', imgList: [ { id: 1, title: 'test1', src: require('./assets/logo1.png') }, { id: 2, title: 'test2', src: require('./assets/logo2.png') }, { id: 3, title: 'test3', src: require('./assets/logo3.png') }, ], }; }, } </script>
이것은 우리가 렌더링한 그림을 루프로 완벽하게 표시할 수 있습니다.
위 내용은 모두를 위해 제가 정리한 내용입니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다.
관련 기사:
js와 jQuery를 사용하여 지정된 할당 방법을 구현하는 방법
위 내용은 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에서 ECharts를 사용하면 애플리케이션에 데이터 시각화 기능을 쉽게 추가할 수 있습니다. 특정 단계에는 ECharts 및 Vue ECharts 패키지 설치, ECharts 소개, 차트 구성 요소 생성, 옵션 구성, 차트 구성 요소 사용, Vue 데이터에 반응하는 차트 만들기, 대화형 기능 추가 및 고급 사용법이 포함됩니다.

C++에서 파일 경로를 얻는 방법은 다음과 같습니다. 1. std::filesystem 라이브러리를 사용합니다. 2. Boost 라이브러리를 사용하십시오. 이러한 메서드를 사용하여 파일의 절대 경로, 루트 디렉터리, 상위 디렉터리 및 확장자를 가져올 수 있습니다. 실제로 이러한 기술은 사용자 인터페이스에 파일 목록을 표시하는 데 사용될 수 있습니다.

질문: Vue에서 내보내기 기본값의 역할은 무엇입니까? 자세한 설명: 내보내기 기본값은 구성 요소의 기본 내보내기를 정의합니다. 가져올 때 구성 요소를 자동으로 가져옵니다. 가져오기 프로세스를 단순화하고 명확성을 높이며 충돌을 방지합니다. 개별 구성 요소를 내보내고, 명명된 내보내기와 기본 내보내기를 모두 사용하고, 전역 구성 요소를 등록하는 데 일반적으로 사용됩니다.

Vue.js 맵 함수는 각 요소가 원래 배열의 각 요소를 변환한 결과인 새 배열을 생성하는 내장된 고차 함수입니다. 구문은 map(callbackFn)입니다. 여기서 callbackFn은 배열의 각 요소를 첫 번째 인수로 받고 선택적으로 인덱스를 두 번째 인수로 받아 값을 반환합니다. map 함수는 원래 배열을 변경하지 않습니다.

onMounted는 Vue의 구성 요소 마운팅 라이프 사이클 후크입니다. 해당 기능은 DOM 요소에 대한 참조 가져오기, 데이터 설정, HTTP 요청 전송, 이벤트 리스너 등록 등과 같은 구성 요소가 DOM에 마운트된 후 초기화 작업을 수행하는 것입니다. 구성 요소가 마운트될 때 한 번만 호출됩니다. 구성 요소가 업데이트된 후 또는 삭제되기 전에 작업을 수행해야 하는 경우 다른 수명 주기 후크를 사용할 수 있습니다.

Vue.js에서 모듈을 내보내는 방법에는 내보내기와 기본값 내보내기라는 두 가지 방법이 있습니다. 내보내기는 명명된 엔터티를 내보내는 데 사용되며 중괄호를 사용해야 합니다. 내보내기 기본값은 기본 엔터티를 내보내는 데 사용되며 중괄호가 필요하지 않습니다. 가져올 때 내보내기로 내보낸 엔터티는 해당 이름을 사용해야 하는 반면, 내보내기 기본값으로 내보낸 엔터티는 암시적으로 사용될 수 있습니다. 여러 번 가져와야 하는 모듈에는 내보내기 기본값을 사용하고, 한 번만 내보내는 모듈에는 내보내기를 사용하는 것이 좋습니다.

Vue 후크는 특정 이벤트 또는 수명 주기 단계에서 작업을 수행하는 콜백 함수입니다. 여기에는 수명 주기 후크(예: beforeCreate, 마운트, beforeDestroy), 이벤트 처리 후크(예: 클릭, 입력, 키다운) 및 사용자 정의 후크가 포함됩니다. 후크는 구성 요소 제어를 강화하고 구성 요소 수명 주기에 응답하며 사용자 상호 작용을 처리하고 구성 요소 재사용성을 향상시킵니다. 후크를 사용하려면 후크 함수를 정의하고 로직을 실행한 후 선택적 값을 반환하면 됩니다.

Vue.js 이벤트 수정자는 다음을 포함한 특정 동작을 추가하는 데 사용됩니다. 기본 동작 방지(.prevent) 이벤트 버블링 중지(.stop) 일회성 이벤트(.once) 이벤트 캡처(.capture) 수동 이벤트 수신(.passive) 적응형 수정자(.self)키 수정자(.key)
