이 글은 주로 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!