环境

win10

node -v 8.9.3

vue-cli 3.4

typescript 3.1.5

编辑器 vscode

目标

使用vuecli工具,建立一个项目,使用typescript.并实现基本的路由,组件等功能

步骤

一.建项目

官网文档https://cli.vuejs.org/zh/guide/creating-a-project.html#vue-create

安装必要的环境,然后使用管理员身份打开CMD输入vue ui:

这个是vuecli的图形化界面,使用它建立比较方便,命令行的命令是vue create

点create开始建立项目,选中带typescript stylus的那种,然后一路下一步,直到项目建完.

这里会从node的npm下载很多包,如果网络不好,会比较慢,还可能失败.

二.熟悉目录结构

使用vscode打开这个项目文件夹

看一下,src目录是源码,根目录下有各种配置文件,那个vue.config.js是后来加上去的,本来没有.

这里并没有发现webpack.config的配置文件,官网上是这样讲的 https://cli.vuejs.org/zh/guide/webpack.html#%E7%AE%80%E5%8D%95%E7%9A%84%E9%85%8D%E7%BD%AE%E6%96%B9%E5%BC%8F

大概是说,vuecli自己生成了webpack配置文件,可能通过增加一个vue.config.js的配置文件来调整webpack的配置,

可以使用如下命令查看生成的配置文件 ,在项目根目录路径下输入这个命令,将配置导出到output.js后查看

三.启动项目

查看package.json的 scripts属性可知,如下命令启动项目

npm run serve

这里看到了经典的vue项目页

运行前,没有改动任何配置

四.项目主要文件与目录

App.vue //

main.ts // 入口文件

router.ts // 路由

store.ts //

/src/views // 可以是页面文件

/src/plugins // 插件目录,例如添加element-ui这个插件后,会增加element.js文件

/src/components // 组件目录,自定义组件可放此处

五.typescript

由于使用了typescript,所以跟js的不太一样,不过在形式上大体一致,

vue js版本中的属性,成员,生命周期,在ts的类中有一一对应的,基本是一致的.

使用ts要比js麻烦一些,至少要多写很多类型定义这些强类型语言的东西,但是也有些好处的,至少有语法提示,重构时还能批量修改等等,另外,语法检查使用了tslint,比较严格.

虽然麻烦,但觉得还是值得的.vscode有建立代码片段的功能,可以建一个vuets的模板,这样比较省事,点击文件菜单

文件 -> 

使用这个模板,这是个vue文件模板,新建一个vue文件后,输入vuets回车就自动输入好了.减少重复劳动

 "Print to console": {
"scope": "vue",
"prefix": "vuets",
"body": [
"<!-- $1 -->",
"<template>",
" <div class=\"\"></div>",
"</template>",
"",
"<script lang=ts>",
"import { Component, Vue, Prop, Watch } from 'vue-property-decorator';",
"@Component",
"export default class $2 extends Vue {",
"}",
"</script>",
"<style lang=stylus scoped>",
"</style>"
],
"description": "Log output to console"
}

六.组件调用传值

以下是一个超连接列表组件,接收一个数组,循环router-link,最终得到a标签列表

 <template>
<div class="list">
<router-link :to="item.path" v-for="(item,index) in data" :key="index">{{item.title}}</router-link>
</div>
</template> <script lang=ts>
import { Component, Vue, Prop, Watch } from 'vue-property-decorator';
@Component
export default class extends Vue {
@Prop()
private data?: [];
private created() {
window.console.log(this.data);
}
}
</script>
<style lang=stylus scoped></style>

与js版本写法上的不同处

这里有个lang=ts,表示使用typescript

这个组件用来扩展功能,提供装饰器?  https://www.tslang.cn/docs/handbook/decorators.html  https://github.com/kaorun343/vue-property-decorator#Prop

有了这个工具后,就可以使用ts的方式来写了.

下面这段代码定义一个ts类,并且继承自Vue,在形式上,和js版本的基本一致

从第1个装饰器 @Component开始,这个的作用就是添加组件,接收一个对象,里面是组件对象,和js的一样

  import com1

  import com2

  components:{com1,com2}

@prop()这个就是js中的属性,下面的成员是属性名,?号表示为可空类型

created()这个方法,就是vue生成周期方法了.与js写法一样.

--调用这个组件:

1.模板部分与js一样,写入模板,并且绑定数据

<list :data="this.data"></list>
 
2.ts部分

import list from list.vue // 与js一样,引入这个组件

// 在组件装饰器中,注册这个组件

@Component({
  components: { list },  
})
 
遇到的一个坑,调用组件传入值时,发现总是报错:
Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-renders. Instead, use a data or computed property based on the prop's value. Prop being mutated: "data"
后来经过网上找资料,说这个意思是,子组件的数据由调用时传入,自己允许修改这个数据,所以一直这个错,
解决方法是,将子组件的属性不设置初始值,也就是只定义属性名,而不设置值,并且也不能修改这个属性.
结果如下

由于ts定义属性一定要赋初值,所以只好定义为可空类型.

七:总结

建项目,熟悉目录与文件,做个组件调用的DEMO,居然也有如此多的坑.

不过好处还是很大的,新版本的cli不用再去折腾并不熟悉的webpack.这降低了上手难度.

ts与vue的结合已经成熟了,后来应该会越来越顺手.

后续还需要一个按目录结构生成路由配置文件的脚本

element-ui和vant两种ui分别用于PC和移动端的界面,还是不错的.但其ts用法,还待研究.

vue+typescript基础练习的更多相关文章

  1. TypeScript基础以及在Vue中的应用

    TypeScript推出已经很长时间了,在Angular项目中开发比较普遍,随着Vue 3.0的即将推出,TypeScript在Vue项目中使用也即将成为很大的趋势,笔者也是最近才开始研究如何在Vue ...

  2. Vue+Typescript中在Vue上挂载axios使用时报错

    Vue+Typescript中在Vue上挂载axios使用时报错 在vue项目开发过程中,为了方便在各个组件中调用axios,我们通常会在入口文件将axios挂载到vue原型身上,如下: main.t ...

  3. Vue + TypeScript + Element 搭建简洁时尚的博客网站及踩坑记

    前言 本文讲解如何在 Vue 项目中使用 TypeScript 来搭建并开发项目,并在此过程中踩过的坑 . TypeScript 具有类型系统,且是 JavaScript 的超集,TypeScript ...

  4. Vue学习记录第一篇——Vue入门基础

    前面的话 Vue中文文档写得很好,界面清爽,内容翔实.但文档毕竟不是教程,文档一上来出现了大量的新概念,对于新手而言,并不友好.个人还是比较喜欢类似于<JS高级程序设计>的风格,从浅入深, ...

  5. Vue组件基础用法

    前面的话 组件(Component)是Vue.js最强大的功能之一.组件可以扩展HTML元素,封装可重用的代码.根据项目需求,抽象出一些组件,每个组件里包含了展现.功能和样式.每个页面,根据自己所需, ...

  6. 一个综合实例讲解vue的基础知识点。

    本文通过一个简单的实例来讲解一下vue的基本知识点.通过这个综合实例的讲解,vue的基础知识就会掌握的差不多了. 首先看一下项目的效果:

  7. Vue入门基础

    前面的话 Vue中文文档写得很好,界面清爽,内容翔实.但文档毕竟不是教程,文档一上来出现了大量的新概念,对于新手而言,并不友好.个人还是比较喜欢类似于<JS高级程序设计>的风格,从浅入深, ...

  8. Vue组件基础

    <!DOCTYPE html><html>    <head>        <meta charset="utf-8">      ...

  9. react router @4 和 vue路由 详解(一)vue路由基础和使用

    完整版:https://www.cnblogs.com/yangyangxxb/p/10066650.html 1.vue路由基础和使用 a.大概目录 我这里建了一个router文件夹,文件夹下有in ...

随机推荐

  1. Java SimpleDateFormat处理日期与字符串的转换

    1.为什么要使用SimpleDateFormat? 在Java中,如果我们想获取当前时间,一般会使用Date类的无参构造函数,如下所示,我们获取到当前时间并输出: import java.util.D ...

  2. Python从零搭建Conf_Web配置管理平台

    环境 CentOS 6/7 x64 Python:2 .7.6 Etcd: 3.2.18 Confd:0 .16.0 Nginx: 1.12.1 效果演示 一,拓扑图: 二.涉及软件 ETD: .分布 ...

  3. ubuntu 安装vm-tool

    1.“虚拟机”->“安装vmware tools”VMware tools 2. 新建一个文件夹 ,打开vmware tools安装介质.右键选择vmwaretools的gz压缩包,选择“提取到 ...

  4. ajax和axios、fetch的区别

    参考文章: https://www.jianshu.com/p/8bc48f8fde75 Fetch API是新的ajax解决方案,用于解决古老的XHR对象不能实现的问题. fetch是用来取代传统的 ...

  5. python 练习 后台返回当前时间

    新建一个 current_time.html 文件, !cur_time! 用来替换 <!DOCTYPE html> <html lang="en"> &l ...

  6. 基于.net EF6 MVC5+WEB Api 的Web系统框架总结(1)-Web前端页面

    本 Web 系统框架基于C# EF6+MVC+WebApi的快速应用开发平台.本节主要介绍Web前端页面设计与实现.Web前端页面主要分为普通列表页面.树状导航列表页面.普通编辑页面.数据导入页面.向 ...

  7. Making A Circle Out Of Squares

    方形画圆 解决方案: 循环偏移5角度画方形 效果图: Python 源码 import turtle; window = turtle.Screen(); window.bgcolor("p ...

  8. 仿EXCEL插件,智表ZCELL产品V1.5 版本发布,IE8/9完全兼容

    详细请移步 智表(ZCELL)官网www.zcell.net 更新说明  这次更新主要应用户要求,主要解决了IE8/9等低版本浏览器兼容的问题,新增了部分功能,欢迎大家体验使用. 本次版本更新内容如下 ...

  9. ARTS打卡第四周

    Algorithm 只出现一次的数字   给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次.找出那个只出现了一次的元素. 说明: 你的算法应该具有线性时间复杂度. 你可以不使用 ...

  10. oracle 基础查询语句

    select abs(10) from dual; --取绝对值select ceil(3.6) from dual;--向上取整 select power(2,3) from dual;--2的3次 ...