一、vite2.0+vue3.0+ts 创建、配置

个人公众号文章地址

个人github仓库地址

1、Vite 创建 vue3 项目:

1.1、npm 常用命令

1、npm 查看版本号

npm view 包 version —— 查看最新版本号

npm view 包 version ——查看所有版本号

2、npm 下载指定版本号

npm install --save-dev 包@版本号

npm install 包@版本号

1.2、vite1.0:

yarn create vite-app <project name>

1.3、vite2.0:
(需要 node 版本>12.0.0)创建项目:vscode 要安装 volar 插件(禁用 vue2.0 的插件 vetur,会冲突)

1、常用命令:

npm init vite@latest

npm init @vitejs/app 项目名

yarn create @vitejs/app 项目名

2、快速新建:

npm init @vitejs/app 项目名 --template vue-ts



1、

2、

3、

4、yarn 安装依赖,启动服务

问题:
1、webpack编译慢(修改一点东西都会把全部文件重新编译)
2、如果想用vue2,则使用vite-plugin-vue2插件

2、基于ts的项目基础配置

2.1、配置 ts 识别vue文件,在项目根目录添加shim.d.ts文件:
declare module "*.vue" {
import { Component } from "vue";
const component: Component;
export default component;
}

文件中即可使用ts语法糖:<script setup lang="ts"></script>

2.2、配置router路由
1、yarn add vue-router@next
2、在项目src目录下面新建router目录,然后添加index.ts文件
️:一定要使用解构导出方法,按照官方文档的会报错
3、将router引入到main.ts中,修改main.ts文件
2.3、配置状态管理:vuex / pinia
1、yarn add vuex@next
2、在项目src目录下面新建store目录,并添加index.ts文件
插件:vuex-persistedstate
2.4、配置axios
1、yarn add axios / npm install --save axios vue-axios
2、在项目src目录下面新建utils/http目录,并添加axios.ts文件
2.5、配置less
1、yarn add less less-loader --dev(建议安装在本地依赖,没必要装全局环境)
2、文件中使用:<style lang="less" scoped></style>
2.6、配置path模块【import {resolve} from "path"】
1、安装依赖:yarn add @types/node --dev
2、vite.config.ts文件中配置:
resolve: {
alias: {
"@": resolve(__dirname, "src"),
}, },

二、vue常用知识点

1、v-if 和 v-for 的优先级

2.x :v-for > v-if
3.x :v-for < v-if

2、v-for 中的 Ref 数组

2.x :自动把ref填充内容
3.x :需要通过 :ref="方法名" 手动添加

3、$children

2.x :访问当前实例的子组件
3.x :$children 被移除,通过ref来访问子组件

4、setup组合API

数据响应区别:
2.x :Object.defineProperty
1、不能监听数组的变化
2、必须遍历对象的每一个属性 3.x :Proxy——不需要遍历
(相当于2.x中的data)
1、 ref——简单类型(需要data.value操作数据)
2、reactive——复杂类型 setup语法糖插件:unplugin-auto-import
yarn add unplugin-auto-import -D
文档地址
无需引入api(eg:import {ref……} from 'vue')

5、toRefs是vue3.x的数据解构,用es6解构会消除proxy的数据响应

6、watch:{}

vue2.x
方法1——改变了才会监听: 监听的值( newVal , oldVal ){}
方法2——配置监听:
监听的值:{
handler( newVal , oldVal ){},
immediate:true, // 是否获取初始化的值
deep:true, // 深度监听——对象这类复杂类型的值
} vue3.x —— 立即监听也可以用watchEffect(相当于: immediate:true)
1、单个监听:
watch(监听的值, (newVal, oldVal) => { console.log(newVal, oldVal); }, { immediate:true,} ) 2、多个监听:
watch([val1 , val2,...], (newVal, oldVal) => { console.log(newVal, oldVal); }, }); 3、监听对象的key值:
watch(()=>obj.key, (newVal, oldVal) => { console.log(newVal, oldVal); })

7、computed

8、父子组件

vue2.x
父传子:props
子传父:$emit
兄弟:eventBus…… vue3.x
父传子:defineProps
子传父:defineEmits
兄弟:mitt(emit、on)

9、插槽(父template、子slot)

1、匿名插槽:会把slot内容都无脑展示出来
2、具名插槽:通过name来进行判断哪些内容展示,哪些不展示
3、作用域插槽:可以父子之间传递数据
4、动态插槽:template可以用变量控制name的具名插槽

10、teleport传送——可以自己选择传送到某个标签下【不容易受到定位的影响】

11、动态组件:

<component :is="变量"></component>
markRow(组件名)——可以绕过proxy

12、异步组件(提升性能)

1、懒加载:组件按需引入(看到组件才加载)
官方:defineAsyncComponent
插件:vueuse 2、axios返回的数据:
<Suspense>
<template #default>异步加载的组件</template>
<template #fallback>加载中</template>
</Suspense> 3、打包会被分包处理:异步组件有单独的js文件,是从主体js文件分包出来的

13、Mixin:混入——复用功能

14、Provide / Inject ——依赖注入——可以忽略父子/父孙的多层级来传递数据

Provide(提供)—— provide('名',data)
Inject(接收)——const num=inject('名')

vue 的个人学习小笔记的更多相关文章

  1. Vue 5小时学习小教程

    Vue Vue Vue 起步 指令 v-bind v-if v-for v-on v-model v-bind和v-on缩写 搭建Vue开发环境 vue项目结构 Vue开始 数据绑定, 绑定属性 循环 ...

  2. # ML学习小笔记—Gradien Descent

    关于本课程的相关资料http://speech.ee.ntu.edu.tw/~tlkagk/courses_ML17.html 根据前面所为,当我们得到Loss方程的时候,我们希望求得最优的Loss方 ...

  3. English - 英语学习小笔记

    1.It is...to do sth:做某事是.... 解析:It 是形式主语,后面一半接形容词做表语,to do sth是不定式短语作真正主语. 2.make do和make doing是两种表达 ...

  4. WEB学习小笔记

    环境基于WIN10.IDEA最新版.JDK1.8.TOMCAT9 下面说的有错的地方希望指出,谢谢. STRUT2 1.在maven下的时候系统会系统创建一个叫做log4j的配置文件,但是到了这个版本 ...

  5. # ML学习小笔记—Classification

    关于本课程的相关资料http://speech.ee.ntu.edu.tw/~tlkagk/courses_ML17.html 通过模型可以分类输入,此时根据分类结果的正确与否会有一个Loss函数.找 ...

  6. SQL 学习小笔记

    1.FOUND_ROWS() 题目: ,; 在上边sql中使用什么选项可以使 SELECT FOUND_ROWS()忽略LIMIT子句,返回总数? *答案* : SQL_CALC_FOUND_ROWS ...

  7. java学习小笔记(三.socket通信)【转】

    三,socket通信1.http://blog.csdn.net/kongxx/article/details/7288896这个人写的关于socket通信不错,循序渐进式的讲解,用代码示例说明,运用 ...

  8. # ML学习小笔记—Where does the error come from?

    关于本课程的相关资料http://speech.ee.ntu.edu.tw/~tlkagk/courses_ML17.html 错误来自哪里? error due to "bias" ...

  9. # ML学习小笔记—Linear Regression

    Regression Output a scalar Model:a set of function 以Linear model为例 y = b+w * $x_cp$ parameters:b,W f ...

随机推荐

  1. java中接口到底是干什么的,怎么用,深入剖析

    6.总结性深一层次综合剖析接口概念[新手可忽略不影响继续学习] 通过以上的学习, 我们知道,所有定义在接口中的常量都默认为public.static和final.所有定义在接口中的方法默认为publi ...

  2. 使用React实现一个TodoList案例

    1.效果图: 2.项目源码 3.源码 TodoList.js import React, { Component, Fragment } from 'react'; import TodoItem f ...

  3. 不同标准下的C语言常量范围的默认类型的检测 (测试样例为C90与C99)

    不同标准下的C语言常量范围的默认类型的检测 一.C90与C99标准下的不同常量范围的默认类型     C90标准下对不同常量范围默认类型的检测实现及运行结果: C99标准下对不同范围默认类型的检测实现 ...

  4. Struts2-向值栈中存放数据

    1.第一种 获取值栈对象,调用值栈对象里面的set方法(该方法添加的是一个Map集合) //第一种方式,使用值栈对象获取对象里面的set方法 //1.获取值栈对象 ActionContext cont ...

  5. 32位x86处理器架构

    我们看看32 位 x86 处理器的基本架构特点.这些处理器包括了 Intel IA-32 系列中的成员和所有 32 位 AMD 处理器. 操作模式 x86 处理器有三个主要的操作模式:保护模式.实地址 ...

  6. ArrayList扩容问题

    今天上午上课在看JavaSE的面经,其中有问关于ArrayList和LinkedList的区别,就突然思考到,既然ArrayList是采用数组形式存储数据,对比我们自己使用到的数组,为什么ArrayL ...

  7. OpenHarmony标准设备应用开发(二)——布局、动画与音乐

    (以下内容来自开发者分享,不代表 OpenHarmony 项目群工作委员会观点) 邢碌 上一章我们讲解了应用编译环境准备,设备编译环境准备,开发板烧录,将一个最简单的 OpenAtom OpenHar ...

  8. 内存之旅——如何提升CMA利用率?

    ​(以下内容来自开发者分享,不代表 OpenHarmony 项目群工作委员会观点)​ 宋远征 李佳伟 OpenAtom OpenHarmony(以下简称"OpenHarmony") ...

  9. 关于Android安装apk出现解析包异常问题情况总结

    原文地址:关于Android安装apk出现解析包异常问题情况总结 | Stars-One的杂货小窝 说之前,可以推荐下各位使用这个开源库AndroidUtilCode,下面提及到的工具类,都是在此库中 ...

  10. Java 15 新特性:文本块

    大家好,我是DD,今天继续来学点Java的新特性! 假设有这样一个场景,我们需要做一个工具.用来自动生成项目文档,文档可以通过浏览器查看,所以最后产出物肯定是一堆html文件.为了让这些html文件更 ...