vue3.0 项目搭建和使用流程


Posted in Vue.js onMarch 04, 2021

最近在重构一个老项目,领导要求使用新的技术栈。好吧,是时候秀一波我新学的vue3.0了。

不多bb,开始我的表演。。。(以下只是我自己个人的理解和使用习惯,仅供参考哦)

一:项目搭建

1. 可以自己配置vite,但是为了节省时间,我就使用脚手架直接搭建。(有兴趣可以研究一下vite,还是很香的)

2. 项目生成:iTerm下: vue create myproject

vue3.0 项目搭建和使用流程

之后根据自己的要求选择不同的配置

vue3.0 项目搭建和使用流程

选择我们需要的3.x

之后按照要求配置一下router,已经pack.json 。。。 然后npm run serve

vue3.0 项目搭建和使用流程

ok。一个基本的3.0项目搭建完成,结束。(那是不可能的)

二: 目录结构

原始的目录结构如下所示:

vue3.0 项目搭建和使用流程

为了方便数据管理,我们需要自定义一些其他的文件。下面是一个简单的demo结构:

vue3.0 项目搭建和使用流程

hooks用来定义一些公共组件的方法,可以在多个组件里面复用,也可以和vuex联用。

typing定义一些你需要使用的ts类型。比如:

vue3.0 项目搭建和使用流程

vue3.0 项目搭建和使用流程

根据不同的组件拆分不同的类型,然后统一在index中导出。index中可以定义一些公共的类型。

request定义一些http请求。

vue3.0 项目搭建和使用流程

base.ts基本路径

api.ts合集api  

http.ts 可以做一下axios请求拦截和配置一下环境。(development, product)

整体配置大致就是这样,把api,以及ts类型集中起来,更方便之后的管理。

在组件内部也需要拆分:

vue3.0 项目搭建和使用流程

这是一个about页面。分为.vue文件和一个内部Hooks的文件夹。.vue文件是基本demo结构。hooks里面根据不同的功能拆分不同的文件。比如:listDownHooks.ts文件就是用来出来下拉菜单的方法集合。还可以单独拆分一个样式文件,(我觉得有点麻烦就没做..)

目录结构就是这样。先在typing定义基本的数据类型,然后再每个组件下的Hooks里面的方法中引入之后在.vue文件里面使用对应的方法。

三: Composition Api

Composition Api是一组基于功能的附加API,可以灵活地组合组件逻辑。配合ts食用更佳~~~

1. defineComponent

从Composition Api中解构出来,配合ts。 定义一个组件:

export default defineComponent({});

如果你不使用ts,也可以使用export default {} 的写法。

2. setup

Composition Api核心的部分,是vue3.0的亮点。替代之前beforeCreate和created生命周期。

vue3.0 项目搭建和使用流程

可以在setup中初始化一些响应式数据。

setup(props, ctx) 接受两个参数,props和ctx(上下文).

props是传统的父传子数据。不建议在setup中解构props,这样会使props失去响应。

ctx中可以解构出,slots,attrs, emit,用法类同于2.0。

3. ref和reactive

用来创建响应式数据的方法。从vue中解构出来  =>    import {ref, reactive} from 'vue';

ref使用:

import {ref, defineComponent} from 'vue';
export default defineComponent({
 setup() {
  const number = ref(0);
  console.log(number); 
  return {
   number
  }
 }
})

通过ref创建一个响应式数据,console看一下。

vue3.0 项目搭建和使用流程

这是一个ref式响应数据,我们在操作的时候通过number.value来操作数据,然后把结果return回去。

ref 声明基本类型和引用类型的区别?

ref声明基本类型,是创建了一个ref的响应式对象

ref声明引用类型,也是创建了一个ref的对象,但是内部是用reactive方法包装的响应式对象

如果你的ref对象被更改在一个reactive里面,可以直接通过key,value方法获取

reactive使用:

import {reactive, defineComponent, toRefs} from 'vue';
export default defineComponent({
 setup() {
  const obj = reactive({   
    menuList: [] as Array<T>
   });
  console.log(number); 
  return {
    ...toRefs(obj);
  }
 }
})

创建一个proxy式的响应数据。通过toRefs将数据return回去。内部是这样的:

vue3.0 项目搭建和使用流程

个人觉得:一些基本类型可以多使用ref定义,对于一个整体的定义,可以使用reactive。

其他:

其他的一些常用的方法比如:computed, watch,等其实用法和2.0差不多。这里不多描述。

四: 基本使用:

用一个基本的新闻列表为例。

vue3.0 项目搭建和使用流程

主要就是在mounted阶段调取数据,在翻页的时候刷新数据。

目录:

src -> views -> News -> Hook ->newsListHook.ts (用来处理列表数据)

在文件中定义一下原始数据。

let dataSource = reactive({
 list: [] as Array<InewsList> // InewsList是数据类型 
});

定义一个newsList() 方法,内部包含一个getList方法用来获取接口数据。一个方法分页请求时候触发,把getList在mounted挂载。之后将数据和方法return出去。代码如下:

/** * 1. 列表请求数据 */import api from '../../../request/api';
import {reactive, onMounted} from 'vue';
import {InewsList} from '../../../typing';
export function newsList(): object { 
 let dataSource = reactive({list: [] as Array<InewsList>});
 function getList(obj: object): void {
  api.newsList(obj).then(res => {
   dataSource.list = res.data.data; })
 };
 function onChange(e: any): void {
  let start = e || 10;
  const obj = {start,num: 10};
  getList(obj);
 }; 
 onMounted(() => {
  const startObj = {start: 1, num: 10};
  getList(startObj);
 }); 
 return {
  dataSource,
  getList,
  onChange
}}

之后src -> views -> News ->News.vue文件中使用。

import {newsList} from './Hook/newslistHook';
export default defineComponent({ 
  name: 'news',
  setup() { 
  const list = newsList();
  return {
   ...list // list中包含着所有定义的数据和方法。
  } 
}})

console一下list:

vue3.0 项目搭建和使用流程

这样就可以直接在vue文件中渲染使用了。

总结一下:把需要用的方还有一些事件(click, mousedown, keyup...)可以放在hook中执行,vue文件就是用来数据渲染。

项目中使用到了antd的Vue框架,大家在使用的时候最好按需加载。毕竟antd太大啦。

import Menu from 'ant-design-vue/es/menu/index'
import Select from 'ant-design-vue/es/select/index'
createApp(App).use(store).use(router).use(Menu).use(Select)

好啦,就到这里啦。新人尝试写vue3.0,不足地方多多指出哦。

以上就是vue3.0 项目搭建和使用流程的详细内容,更多关于vue3.0 项目搭建和使用的资料请关注三水点靠木其它相关文章!

Vue.js 相关文章推荐
VUE项目实现主题切换的多种方法
Nov 26 Vue.js
vue+element_ui上传文件,并传递额外参数操作
Dec 05 Vue.js
基于vuex实现购物车功能
Jan 10 Vue.js
vue监听键盘事件的相关总结
Jan 29 Vue.js
vue登录页实现使用cookie记住7天密码功能的方法
Feb 18 Vue.js
vue实现可移动的悬浮按钮
Mar 04 Vue.js
vue3.0 项目搭建和使用流程
Mar 04 Vue.js
vue项目实现分页效果
Mar 24 Vue.js
vue 实现上传组件
May 31 Vue.js
vue项目支付功能代码详解
Feb 18 Vue.js
Vue+TypeScript中处理computed方式
Apr 02 Vue.js
vue cli4中mockjs在dev环境和build环境的配置详情
Apr 06 Vue.js
vue 数据双向绑定的实现方法
Mar 04 #Vue.js
vue3.0中使用element的完整步骤
Mar 04 #Vue.js
VUE实现吸底按钮
Mar 04 #Vue.js
vue实现可移动的悬浮按钮
Mar 04 #Vue.js
vue中axios封装使用的完整教程
Mar 03 #Vue.js
详解Vue.js 可拖放文本框组件的使用
Mar 03 #Vue.js
详解vue3中组件的非兼容变更
Mar 03 #Vue.js
You might like
JAVA/JSP学习系列之二
2006/10/09 PHP
php生成随机密码的几种方法
2011/01/17 PHP
PHP通过串口实现发送短信
2015/07/08 PHP
php用户注册信息验证正则表达式
2015/11/12 PHP
KindEditor在php环境下上传图片功能集成的方法示例
2020/07/20 PHP
文本链接逐个出现的js脚本
2007/12/12 Javascript
JavaScript和JQuery实用代码片段(一)
2010/04/07 Javascript
jquery实用代码片段集合
2010/08/12 Javascript
JQuery入门—编写一个简单的JQuery应用案例
2013/01/03 Javascript
基于javascript的COOkie的操作实现只能点一次
2014/12/26 Javascript
js实现圆盘记速表
2015/08/03 Javascript
比较常见的javascript中定义函数的区别
2015/11/09 Javascript
vue.js入门教程之基础语法小结
2016/09/01 Javascript
H5用户注册表单页 注册模态框!
2016/09/17 Javascript
微信小程序 教程之条件渲染
2016/10/18 Javascript
nodeJS删除文件方法示例
2016/12/25 NodeJs
javascript正则表达式模糊匹配IP地址功能示例
2017/01/06 Javascript
js实现视图和数据双向绑定的方法分析
2020/02/05 Javascript
Python实现端口复用实例代码
2014/07/03 Python
对于Python的Django框架部署的一些建议
2015/04/09 Python
Python找出9个连续的空闲端口
2016/02/01 Python
python生成带有表格的图片实例
2019/02/03 Python
对Python中的条件判断、循环以及循环的终止方法详解
2019/02/08 Python
Python使用enumerate获取迭代元素下标
2020/02/03 Python
Python中内建模块collections如何使用
2020/05/27 Python
python实现数据结构中双向循环链表操作的示例
2020/10/09 Python
十一个高级MySql面试题
2014/10/06 面试题
公司活动邀请函
2014/01/24 职场文书
房地产公司见习自我鉴定
2014/04/28 职场文书
农村门前三包责任书
2014/07/25 职场文书
办理房产证委托书
2014/09/18 职场文书
派出所副所长四风问题个人整改措施思想汇报
2014/10/13 职场文书
2016年高校自主招生自荐信范文
2015/03/24 职场文书
2015年司机工作总结
2015/04/23 职场文书
新店开张宣传语
2015/07/13 职场文书
利用Sharding-Jdbc进行分库分表的操作代码
2022/01/22 Java/Android