前端DAY01
1、基于脚手架创建前端工程
data:image/s3,"s3://crabby-images/63e7d/63e7d78021e1180043bce794787c609ef4b34a10" alt=""
使用Vue CLI创建前端工程:
- 方式一:vue create 项目名称
- 方式二:vue ui(比较慢)
data:image/s3,"s3://crabby-images/c47d8/c47d8ff635f518742af0b1fc4af632c4f47b0ad2" alt=""
data:image/s3,"s3://crabby-images/52071/520718ba345018ae9561fe61cd8e3074e246f8e4" alt=""
2、vue基本使用方法
Vue的组件文件以.vue结尾,每个组件由三个部分组成:
data:image/s3,"s3://crabby-images/5cfdc/5cfdc963ff2e6fc8a8add185404c2bbdc47006d9" alt=""
文本差值
data:image/s3,"s3://crabby-images/0d71c/0d71c17435e5c793feac5f583b91922afa7ee75d" alt=""
属性绑定
data:image/s3,"s3://crabby-images/49844/49844960adee2782608b221c51df245a484220a8" alt=""
事件绑定
data:image/s3,"s3://crabby-images/3c309/3c30938afa4e2519d81998759fab8689589b9434" alt=""
双向绑定
data:image/s3,"s3://crabby-images/d45d2/d45d2e0fdf821fff8ef0a6b254d9f77f70e683e1" alt=""
条件渲染
data:image/s3,"s3://crabby-images/5bc51/5bc51942f36af1159145308910c244061d9412b1" alt=""
axios
axios是一个基于promise的网络请求库,作用于浏览器和node.js中
安装命令
- npm install axios
导入命令
- import axios from 'axios'
data:image/s3,"s3://crabby-images/0fd38/0fd3873e39bee92cfc3d34978fe4b5dc66aa2aec" alt=""
data:image/s3,"s3://crabby-images/acd95/acd95c0c2f50103221face0f22a9bc5d25247f71" alt=""
data:image/s3,"s3://crabby-images/0d795/0d795cb491d10c5e438387d7ed0dce0374217261" alt=""
3、路由 Vue-Router
3.1、Vue-Router介绍
vue属于单页面应用,所谓的路由,就是根据浏览器路径 不同,用不同的视图组件替换这个页面内容
- 路由组成:
- VueRouter:路由器,根据路由请求在路由视图中动态渲染对应的视图组件
- :路由链接组件,浏览器回解析成
- :路由视图组件,用来展示与路由路径匹配的视图组件
data:image/s3,"s3://crabby-images/7a75c/7a75c2cbac6074aa62ee736128cfb7336f1ae65b" alt=""
3.2、路由配置
- 路由跳转
- 标签式About
- 编程式
this.$router.push('/about')
data:image/s3,"s3://crabby-images/4cf72/4cf726b886f4c465c3dec240acb85170e7488b35" alt=""
3.3、嵌套路由
组件内要切换内容,就需要用到嵌套路由(子路由)
data:image/s3,"s3://crabby-images/9f6c2/9f6c22c33491fd94c376dc9aece3a92c28be7f0b" alt=""
- 实现步骤:
- 安装并导入elementui,实现页面布局(Container布局容器)---ContainerView.vue
- 提供子视图组件,用于效果展示 -- P1View.vue、P2View.vue、P3View.vue
- 在src/router/index.js中配置路由映射规则(嵌套路由配置)
- 在布局容器视图中添加,实现子视图组件展示
- 在布局容器视图中添加,实现路由请求
4、状态管理vuex
4.1、vuex介绍
- vuex是一个专为Vue.js应用程序开发的状态管理库
- vuex可以在多个组件之间共享数据,并且共享的数据是响应式的,即数据的变更能及时渲染到模版
- vuex采用集中式存储管理所有组件的状态
安装vuex
npm install vuex@next --save
核心概念:
- state:状态对象,集中定义各个组件共享的数据
- mutations:类似于一个事件,用于修改共享数据,要求必须是同步函数
- actions:类似于mutation,可以包含异步操作,通过调用mutation来改变共享数据
4.2、使用方式
- 创建带有vuex功能的脚手架工程
data:image/s3,"s3://crabby-images/2d1ff/2d1ff641e026523859ff517f6f4b304d106aba5a" alt=""
- 定义和展示共享数据
data:image/s3,"s3://crabby-images/7809d/7809de4b16fb27c67686f57169ce3f2668d45b8f" alt=""
- 在mutations中定义函数,修改共享数据
data:image/s3,"s3://crabby-images/655df/655df447bea333b62e7349b95f0bd9f645e38139" alt=""
- 调用mutations中的函数
data:image/s3,"s3://crabby-images/5fbfc/5fbfcd017b18510e40436ff8d5e4dba63b333649" alt=""
- 在actions中定义函数,用于调用mutation
data:image/s3,"s3://crabby-images/caf10/caf10b4e36d1e8bd3018f427b05983097996195e" alt=""
总结:如何使用vuex?
- 在store对象的state属性中定义共享数据
- 在store对象的mutations属性中定义修改共享数据的函数
- 在store对象的actions属性中定义调用mutation的函数,可以进行异步操作
- mutations中的函数不能直接调用,只能通过store对象的commit方法调用
- actions中定义的函数不能直接调用,只能通过store对象dispatch方法调用
5、TypeScript
5.1、 TypeScript介绍
-
TypeScript(简称:TS)是微软退出的开源语言
-
TypeScript是JavaScript的超集(JS有的TS都有)
-
TypeScript = Type + JavaScript(在Js基础上增加了类型支持)
-
TypeScript文件扩展名为ts
-
TypeScript可编译成标准的JavaScript,并且在编译时进行类型检查
TS为什么要增加类型支持?
- TS属于静态类型编程语言,JS属于动态类型编程语言
- 静态类型在编译期做类型检查,动态类型在执行期做类型检查
5.2、TypeScript常用类型
data:image/s3,"s3://crabby-images/ce204/ce204050da8b2a564f52344d4147ebd5a4aa68fd" alt=""
- 类型标注的位置
- 标注变量
- 标注参数
- 标注返回值
data:image/s3,"s3://crabby-images/00b32/00b32345544186c3fd67d94e08c40c1e14e33f68" alt=""
- 字符串类型、数字类型、布尔类型
data:image/s3,"s3://crabby-images/46519/46519e515f57a363673c748efde63c8d7dc656fc" alt=""
- 字面量类型
data:image/s3,"s3://crabby-images/b7e5b/b7e5baa17dbd3bd6add1089a76eaf985d628f16a" alt=""
- Interface类型
data:image/s3,"s3://crabby-images/ba36b/ba36ba979bdb3d189c1182c73f649e30a6483196" alt=""
- class类-基本使用
data:image/s3,"s3://crabby-images/982f8/982f81bb5e7602aac281a5001f14d33abc803561" alt=""
注意:使用class关键字来定义类,类中可以包含属性、构造方法、普通方法
- class类 - 实现接口
data:image/s3,"s3://crabby-images/6c8ca/6c8cae080e0661b449ca6b01c1b366a90d37c3e2" alt=""
- class类 - 类的继承
data:image/s3,"s3://crabby-images/266f2/266f24a6d952a2270a60783f241e3f4f0098d8fd" alt=""