vue3.0+vite+ts项目搭建--基础配置(二)
集成vue-router
使用yarn
yarn add vue-router@next --save
安装完成之后在src
目录下创建文件夹router/index.ts
,创建完成之后需要在Vue-Router
中对Vue-Router
进行初始化配置。我们暂时把初始化的工作搁置一下,先需要创建pages
文件夹,把需要展示的页面创建完成。
创建完成之后,接下来就是完善router/index.ts
中文件的初始化工作了:
- import { createRouter, createWebHashHistory } from "vue-router";
- const router = createRouter({
- history: createWebHashHistory(),
- routes: [
- {
- path: "/home",
- name: "Home",
- alias: "/",
- component: () => import("../pages/Home.vue")
- },
- {
- path: "/about",
- name: "About",
- component: () => import("../pages/About.vue")
- }
- ]
- })
- export default router;
接下来在main.ts
文件中集成Vue-Router
:
- import { createApp } from 'vue';
- import App from './App.vue';
- import router from "./router";
- const app = createApp(App);
- app.use(router);
- app.mount('#app');
测试一下,这里修改一下App.vue
的代码,测试一下我们的路由是否已经可以正常使用了。
- <template>
- <router-link to="/home">Home</router-link>
- <router-link to="/about">About</router-link>
- <router-view></router-view>
- </template>
- <script lang="ts">
- import { defineComponent } from 'vue'
- export default defineComponent({
- name: 'App'
- })
- </script>
接下来启动服务就可以看到所配置的页面了,说明配置的路由已经生效了。
集成Vuex
使用 Yarn
yarn add vuex@next --save
安装完成之后,首先添加store/index.ts
来初始化Vuex
。需要注意的是,如下示例使用了Vuex
命名空间。可能在实际项目中使用命名空间相对来说还是比较普遍的,避免进行状态管理的时候导致变量污染。
- import { createStore } from "vuex";
- const store = createStore({
- modules: {
- home: {
- namespaced: true,
- state: {
- count: 1
- },
- mutations: {
- add(state){
- state.count++;
- }
- }
- }
- }
- })
- export default store;
集成到Vue
中:
- import { createApp } from 'vue';
- import App from './App.vue';
- import router from "./router";
- import store from "./store";
- const app = createApp(App);
- app.use(router);
- app.use(store);
- app.mount('#app');
现在Vuex
就已经被集成到Vue
中了为了保证集成的Vuex
是有效地,那么需要对此进行测试:
pages/Home.vue
- <template>
- <h1>Home</h1>
- <h2>{{count}}</h2>
- <button @click="handleClick">click</button>
- </template>
- <script lang="ts">
- import { defineComponent, computed } from 'vue';
- import { useStore } from 'vuex';
- export default defineComponent({
- setup () {
- const store = useStore();
- const count = computed(() => store.state.home.count);
- const handleClick = () => {
- store.commit('home/add');
- };
- return {
- handleClick,
- count
- };
- }
- })
- </script>
当点击按钮的时候,就可以发现count
值也随着点击每次递增,那么store
是可以正常使用.
引入Vant框架
这边使用的是vant3.0框架
引入按需加载插件
- yarn add vant@next -S
- yarn add vite-plugin-style-import -D
配置按需加载
vite.config.ts中配置
- import styleImport from 'vite-plugin-style-import'
- plugins: [
- vue(),
- styleImport({
- libs: [{
- libraryName: 'vant',
- esModule: true,
- resolveStyle: (name) => {
- return `vant/es/${name}/style/css`;
- },
- }]
- })
- ]
main.ts中配置
- import Vant from 'vant'
- import 'vant/lib/index.css'
- const app = createApp(App)
- app.use(Vant)
- app.mount('#app')
按需加载有待完善,目前是配置CDN加载
vite.config.ts中配置
- {
- name:'vue',
- var:'Vue',
- path:'https://cdn.jsdelivr.net/npm/vue@next'
- },
- {
- name:'vant',
- var:'vant',
- css: 'https://cdn.jsdelivr.net/npm/vant@next/lib/index.css',
- path:'https://cdn.jsdelivr.net/npm/vant@next/lib/vant.min.js'
- }
main.ts中正常引用
- import Vant from 'vant'
- app.use(Vant)
CDN配置
- yarn add vite-plugin-cdn-import -D
vite.config.ts配置示例文件如下
- import importToCDN, { autoComplete } from 'vite-plugin-cdn-import'
- plugins: [
- vue(),
- importToCDN({
- modules: [
- autoComplete('lodash'),
- {
- name:'ant-design-vue',
- var:'antd',
- path:'https://cdn.jsdelivr.net/npm/ant-design-vue@2.2.0-beta.6/dist/antd.js',
- css:'https://cdn.jsdelivr.net/npm/ant-design-vue@2.2.0-beta.6/dist/antd.min.css'
- }
- ]
- })
- ]
自动完成(autoComplete)支持的模块如下:
- "react" | "react-dom" | "react-router-dom" |
- "antd" | "ahooks" | "@ant-design/charts" |
- "vue" | "vue2" | "@vueuse/shared" |
- "@vueuse/core" | "moment" |
- "eventemitter3" | "file-saver" |
- "browser-md5-file" | "xlsx | "crypto-js" |
- "axios" | "lodash" | "localforage"
分包配置
在vite.config.ts的build中做如下配置
- rollupOptions: {
- treeshake: false,
- output: {
- manualChunks (id) {
- if (id.includes('node_modules')) {
- return id.toString().split('node_modules/')[1].split('/')[0].toString()
- }
- }
- }
- }
参考:Vite开发环境搭建
vue3.0+vite+ts项目搭建--基础配置(二)的更多相关文章
- vue3.0+vite+ts项目搭建--初始化项目(一)
vite 初始化项目 使用npm npm init vite@latest 使用yarn yarn create vite 使用pnpm pnpx create-vite 根据提示输入项目名称,选择v ...
- vue3.0+vite+ts项目搭建--vite.config.ts配置(三)
vite.config.ts配置 配置路径处理模块 安装ts的类型声明文件 yarn add @types/node -D 通过配置alias来定义路径的别名 resolve: { alias: { ...
- vue3.0+vite+ts项目搭建-postcss-pxtorem 实现移动自适应(五)
这里不考虑大屏,所以不做amfe-flexible的配置 首先是安装依赖 yarn add postcss-loader postcss-pxtorem -D yarn add autoprefixe ...
- vue3.0+vite+ts项目搭建-分环境打包(四)
分环境打包配置 新建.env.dev(或者.env) VITE_NODE_ENV = 'dev' VITE_HOST = 'http://local.host.com' 执行yarn dev ,控制台 ...
- vue3.0+vite+ts项目搭建(报错处理)
报错一 warning package.json: No license field$ vue-tsc --noEmit && vite build 解决方案,添加这两行,只添加一个是 ...
- vue3.0+vite+ts项目搭建-axios封装(六)
封装方式一 import axios from 'axios' import qs from 'qs' import { Toast } from 'vant' import Lockr from ' ...
- Asp.Net Core 项目搭建 基础配置 和MySql 的使用
一.开发环境准备 1.安装Visual Studio 2015,我这里安装的是专业版. 2.安装.NET Core SDK相关 需要安装 Visual Studio 2015 update3和NET ...
- vite + ts 快速搭建 vue3 项目 以及介绍相关特性
博客地址:https://ainyi.com/98 Vue3.0,One Piece 接下来得抽空好好学习了 vite 尤大在 Vue 3.0 beta 直播中推荐了 vite 的工具,强调:针对Vu ...
- vue3.0脚手架 创建项目
1.下载node最新稳定版本,并且安装 2.安装好之后,在cmd或者terminal下, 使用npm -v 查看当前npm版本,验证是否安装成功 3.安装成功后,运行 npm i -g @vue/cl ...
随机推荐
- antd动态的表格合并(包含排序功能)
主要是两个步骤, 1.处理接口返回数据,给其添加两个属性,一个是合并行数(列数),一个是当前数据的序号 2.在columns结合antd官网的处理方法合并表格 3.尽可能得减少计算量 数据处理函数 / ...
- 估计工期标识(Project)
<Project2016 企业项目管理实践>张会斌 董方好 编著 有时候吧,我们遇到的任务,工期并不是那么好定的,本来嘛,一个项目如果全靠拍脑袋,最后搞不好会被人锤脑袋-- 看来PM有风险 ...
- AT5341 [ABC156D] Bouquet 题解
Content 有一个人有 \(n\) 种不同的话可供选择,TA 可以选择至少一种花做花束,但是 TA 不喜欢花的种数为 \(a\) 或者 \(b\) 的花束.求选花的方案数对 \(10^9+7\) ...
- IDEA添加yaml自动补全语法插件
问题:编写yml文件的时候,系统不能给自动补全 解决办法:File---->Settings---->Plugins---->搜索Spring Assistant x 项目效果预览
- JAVA中价格金额的存储类型
在java项目中,我们会遇到价格.金额的数据,这时候我们java中应该用BigDecimal类型,数据库用decimal类型, 长度可以自定义, 如18; 小数点我们项目中用的是2, 保留2位小数. ...
- 基于 SoC 的卷积神经网络车牌识别系统设计(0)摘要
NOTES:现如今,芯片行业无比火热啊,无论是前景还是钱景,国家芯片战略的发布,公司四五十万的年薪,着实令人非常的向往,为了支持芯片设计者,集成了工作.科研.竞赛于一体的<基于 SoC 的卷积 ...
- 网络编程之新函数inet_pton和inet_ntop
1.头文件 1 #include <arpe/inet.h> 2.inet_pton 函数 A.原型 1 int inet_pton(int family, const char *str ...
- 【九度OJ】题目1138:进制转换 解题报告
[九度OJ]题目1138:进制转换 解题报告 标签(空格分隔): 九度OJ 原题地址:http://ac.jobdu.com/problem.php?pid=1138 题目描述: 将一个长度最多为30 ...
- github项目托管方式(看项目自身是否自带有 .git)
一.本地仓库和远程仓库建立联系 方式一:项目自身带有 .git文件的[自身就是一个本地仓库的](这里咱以vue-cli3项目为例) 1.创建自带.git本地仓库:创建一个叫 my-vue 的项目 2. ...
- 牛客练习赛44 C:小y的质数
链接:https://ac.nowcoder.com/acm/contest/634/C?tdsourcetag=s_pcqq_aiomsg 来源:牛客网 题目描述 给出一个区间\([L,R]\),求 ...