Vue2 Vue-cli에서 Typescript를 사용하는 구성 소개
이 글은 주로 Vue2 Vue-cli에서 Typescript를 사용하는 구성을 소개합니다. 참고할만한 가치가 있어서 공유합니다. 도움이 필요한 친구들이 참고할 수 있습니다.
Vue는 3대 프론트엔드 프레임워크 중 하나입니다. 지금까지 github에서 44,873개의 별을 받았는데, 이는 조용히 주류가 되었음을 보여주기에 충분합니다. 다음 글에서는 Vue2 Vue-cli에서 Typescript를 사용하는 구성에 대한 관련 정보를 주로 소개합니다. 필요한 친구들이 참고할 수 있습니다.
머리말
회사 팀이 최근 vue 프레임워크에 푹 빠져 있고, 새로운 프로젝트에서 typescript를 연습하고 싶어서 vue+ts의 여정을 시작하게 되었어요... 이 글은 저와 같은 생각을 갖고 계시다면, 함정에 빠질 시간을 절약하세요. Vue2 Vue-cli에서 Typescript를 사용하는 데 필요한 구성에 대해서는 더 이상 설명하지 않겠습니다.
1. 초기 구성
먼저 공식 플러그인인 vue-class-composite, vue-property-designer를 설치하고 webpack을 구성합니다.
웹팩 구성은 다음과 같습니다.
항목 파일 수정
entry: { app: './src/main.ts' }
해결 부분:
extensions: ['.js', '.vue', '.json', '.ts', '.tsx']
로더 구성
{ test: /\.tsx?$/, loader: 'ts-loader', exclude: /node_modules/, options: { appendTsSuffixTo: [/\.vue$/], } }
tsconfig.json 구성
{ "include": [ "src/**/*" ], "exclude": [ "node_modules" ], "compilerOptions": { "allowSyntheticDefaultImports": true, "experimentalDecorators": true, "allowJs": true, "module": "es2015", "target": "es5", "moduleResolution": "node", "experimentalDecorators": true, "isolatedModules": true, "lib": [ "dom", "es5", "es2015.promise" ], "sourceMap": true, "pretty": true } }
2. 실전 전투!
구성 설정은 첫 번째 단계일 뿐이며 프로젝트에서 실행하는 것이 핵심입니다.
vue 파일의 스크립트 태그에 lang='ts'
를 추가하세요lang='ts'
因为ts-loader不像配过loader的webpack一样知道vue,html等文件是什么东西,你跑起来后会报模块无法解析的错误,所以还需要配置.d.ts声明文件
vue的如下配置
declare module "*.vue" { import Vue from 'vue'; export default Vue; }
你也可以为其它的非js模块配置.d.ts文件如html(告诉ts-loader把html理解成字符串)
declare module "*.html" { let template: string; export default template; }
配置好之后ts就能理解这些模块了
从vue-property-decorator引入需要用到的模块
(一般只用到Component, Vue, Watch, Prop这四个,其它3个没用到也没研究,知道的大佬可以解释下。)
import { Component, Vue, Watch } from 'vue-property-decorator'
vue의 다음 구성
class HoverTopElem { leaveTop: number = -200 top: number = null height: number = null show(e) { this.top = e.target.getBoundingClientRect().top this.height = e.target.clientHeight } hidden() { this.top = this.leaveTop } } @Component({ name: 'sidebar', template: template, components: { sidebarItem } }) export default class Sidebar extends Vue { SidebarMenu: any = SidebarMenu hoverTopElem: HoverTopElem = new HoverTopElem() activeListItemName: string = null activeRouteItemRoute: string = null get _activeRouteItemRoute(): string { return this.$route.path } @Watch('_activeRouteItemRoute', { immediate: true }) onRouteChanged(val: any) { this.activeRouteItemRoute = val } changeList(param) { this.activeListItemName = param } changeRoute(param) { this.activeRouteItemRoute = param } }
.d.ts도 구성할 수 있습니다 html과 같은 기타 비-js 모듈용 파일(ts-loader에게 html을 문자열로 이해하도록 지시)
rrreee구성 후 ts는 이러한 모듈을 이해할 수 있습니다
vue-property-designator에서 필요한 모듈 소개
(일반적으로 Component, Vue, Watch, Prop만 사용합니다. 나머지 3개는 사용하지 않고 연구도 해본 적이 없습니다. 아는 사람이 설명해줄 수 있습니다.)
import { Component, Vue, Watch } from 'vue.-property- decorator'
다음은 이전에 작성한 sidbar 코드의 예입니다.
rrreee메타데이터는 이름, 사용된 구성 요소와 같은 @Component 구성으로 작성됩니다. , etc. 그런 다음 이전에 vue에서 사용된 각 인스턴스 속성 메소드를 사용하는 방법에 대해 이야기하겠습니다. data: 위의 SidebarMenu와 같이 가장 일반적으로 사용됩니다(여기에는 총 4개가 선언되어 있습니다). 값은 할당되어야 합니다. 그렇지 않은 경우 값은 null이고 정의되지 않을 수 없습니다. 그렇지 않으면 데이터가 응답하지 않습니다. 따라서 HoverTopElem 클래스의 속성에도 초기 값이 있어야 합니다. 그렇지 않으면 이러한 속성이 응답하지 않습니다. 계산됨: 여기에 tsconfig.jsonp가 "target": "es5"를 구성하지 않으며 오류가 발생합니다. 여기에 보고됩니다. Prop: vue- Property-Decorator에 Prop 모듈이 있습니다. 메타데이터에서 이 Prop을 선언한 다음, 클래스에서 이 변수를 선언할 수도 있습니다. 저는 개인적으로 첫 번째 것을 추천합니다. Watch: vue- property-decorator
vue 보기- 라우팅 후크를 위한 클래스 컴포넌트 문서이때 기본적으로 이전과 같이 Vue 컴포넌트를 작성할 수 있습니다.
관련 권장 사항:
🎜Vue 배경 이미지 패키징 후 잘못된 액세스 경로 문제를 해결하는 방법 🎜🎜🎜🎜🎜casperjs 및like.js 기반의 픽셀 비교 서비스 구현 🎜🎜🎜🎜🎜이후 처음으로 초기화 vue 프로젝트가 생성됩니다. 스타일러스를 이용한 설치 방법 소개🎜🎜🎜🎜🎜🎜🎜🎜🎜위 내용은 Vue2 Vue-cli에서 Typescript를 사용하는 구성 소개의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











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

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

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

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

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

VUE 멀티 페이지 개발은 vue.js 프레임 워크를 사용하여 응용 프로그램을 구축하는 방법입니다. 여기서 응용 프로그램은 별도의 페이지로 나뉩니다. 코드 유지 보수 : 응용 프로그램을 여러 페이지로 분할하면 코드를보다 쉽게 관리하고 유지 관리 할 수 있습니다. 모듈 식 : 각 페이지는 쉬운 재사용 및 교체를 위해 별도의 모듈로 사용할 수 있습니다. 간단한 라우팅 : 페이지 간의 탐색은 간단한 라우팅 구성을 통해 관리 할 수 있습니다. SEO 최적화 : 각 페이지에는 자체 URL이있어 SEO가 도움이됩니다.

VUE에서 DIV 요소를 점프하는 두 가지 방법이 있습니다. VUE 라우터를 사용하고 라우터 링크 구성 요소를 추가하십시오. @Click 이벤트 리스너를 추가하고 이것을 호출하십시오. $ router.push () 메소드를 점프하십시오.

vue.js의 Foreach 루프는 V-For 지시문을 사용하여 개발자가 각 요소를 배열 또는 객체에서 반복하고 각 요소에서 특정 작업을 수행 할 수 있습니다. 구문은 다음과 같습니다. & lt; template & gt; & lt; ul & gt; & lt; li v-for = & quot; 항목의 항목 & gt; {{item}} & lt;/li & gt; & lt;/ul & gt; & lt;/template & gt; & am
