项目实战 之 vue3 + vite + pinia

news2025/1/20 22:45:08

目录

一、创建项目

1. 安装vite

2. 创建项目

3. 安装过程

二、项目基本配置

1. 项目icon

2. 项目标题

3. 配置 jsconfig.json

4. 设置 .prettierrc 文件

5. 生成代码片段 

01 - 网址

02 - 生成

03 - 配置

04 - 使用

三、项目目录 结构划分

1. assets

2. components

3. hooks

4. mock

5. router

6. service

7. stores

8. utils

9. views

四、css 样式重置

1. normalize.css

01 - 安装

02 - 引入

2. reset.css

01 - 代码

02 - 引入

3. common.css

01 - 代码

02 - 引入 

五、vue-router 路由配置

1. 安装

2. 配置

3. 引入 

4. 使用 

六、pinia 状态管理

1. 安装

2. 创建

3. 引入

4. 模块

七、把代码推送到远程仓库

1. 初始化git仓库

2. 配置 name 和 email

3. 提交代码到本地

4. 生成远程仓库

5. 本地和远程连接

八、项目正在开发中 🌰

1. 使用百度地图插件

01 - 注册并登录百度账号 百度地图开放平台 | 百度地图API SDK | 地图开发

02 - 成为开发者

        点击控制台

        填写资料进行注册​​​​​​​

03 - 创建应用

        创建应用

        获取AK

04 - 使用JavaScript API文档

        复制js代码,在index.html中引入

        展示地图

        效果

2. 监听页面的滚动

01 - 封装usePageScroll.js

02 - 使用

03 - 效果 

3. 加载assets文件夹中的图片 

01 - 封装load_assets.js

02 - 使用


​​​​​​​一、创建项目

1. 安装vite

npm i vite -g

2. 创建项目

npm init vue@latest

3. 安装过程

二、项目基本配置

1. 项目icon

public目录 下,添加一个 favicon.icon 图片

2. 项目标题

index.html 文件的 title标签 中配置

3. 配置 jsconfig.json

能让 代码提示 变得更加友好

{
  "compilerOptions": {
    // "target": "es5",
    "module": "esnext",
    "baseUrl": "./",
    "moduleResolution": "node",
    "paths": {
      "@/*": [
        "src/*"
      ]
    },
    "lib": [
      "esnext",
      "dom",
      "dom.iterable",
      "scripthost"
    ]
  },
  "vueCompilerOptions": {
    "experimentalDisableTemplateSupport": true
  }
}

4. 设置 .prettierrc 文件

{
  "printWidth": 120, 
  "singleQuote": true,
  "bracketSpacing": true,
  "jsxBracketSameLine": false,
  "htmlWhitespaceSensitivity": "ignore",
  "useTabs": false,
  "tabWidth": 2,
  "endOfLine": "lf",
  "trailingComma": "none",
  "semi": true,
  "eslintIntegration": true
}

5. 生成代码片段 

01 - 网址

代码片段生成网址 : snippet generator

02 - 生成

"vue3": {
	"prefix": "vue3",
	"body": [
		"<!-- ? ${2}模块 -->",
		"<template>",
		"  <div class=\"${1}-view\">",
		"    <h2>${1}</h2>",
		"  </div>",
		"</template>",
		"",
		"<script setup>",
		"import { ref } from 'vue';",
		"</script>",
		"",
		"<style lang=\"scss\" scoped>",
		".${1}-view {",
		"}",
		"</style>",
		""
	],
	"description": "vue3"
}

03 - 配置

设置     =>    配置用户代码片段     =>    vue.json     =>    copy

04 - 使用

使用设置的title即可     =>    tab键 切换占位符1. 2. 3. 4 ...

三、项目目录 结构划分

1. assets

存放 => 静态资源

  • css   =>   样式重置
  • img   =>   图片文件
  • font   =>   字体文件

2. components

存放 => 公共组件

3. hooks

存放 => 公共常用的hook

4. mock

存放 => 模拟接口数据

5. router

存放 => 路由管理

6. service

存放 => 接口请求

7. stores

存放 => 状态管理

8. utils

存放 => 插件、第三方插件

9. views

存放 => 视图、页面

四、css 样式重置

自定义的css公共文件放置在assets中的css文件中即可

1. normalize.css

01 - 安装

npm i normalize.css

02 - 引入

// 在 main.js 中引入
import 'normalize.css';

2. reset.css

01 - 代码

 html,
 body,
 div,
 span,
 applet,
 object,
 iframe,
 h1,
 h2,
 h3,
 h4,
 h5,
 h6,
 p,
 blockquote,
 pre,
 a,
 abbr,
 acronym,
 address,
 big,
 cite,
 code,
 del,
 dfn,
 em,
 font,
 img,
 ins,
 kbd,
 q,
 s,
 samp,
 small,
 strike,
 strong,
 sub,
 sup,
 tt,
 var,
 b,
 u,
 i,
 center,
 dl,
 dt,
 dd,
 ol,
 ul,
 li,
 fieldset,
 form,
 label,
 legend,
 caption {
     margin: 0;
     padding: 0;
     border: 0;
     outline: 0;
     font-size: 100%;
     vertical-align: baseline;
     background: transparent;
 }
 
 table,
 tbody,
 tfoot,
 thead,
 tr,
 th,
 td {
     margin: 0;
     padding: 0;
     outline: 0;
     font-size: 100%;
     vertical-align: baseline;
     background: transparent;
 }
 
 button,
 input,
 textarea {
     margin: 0;
     padding: 0;
 }
 
 
 /* form elements 表单元素 */
 
 body,
 button,
 input,
 select,
 textarea {
     font: normal 12px/1.5 '\5FAE\8F6F\96C5\9ED1', tahoma, arial;
 }
 
 
 /*设置的字体,行高*/
 
 h1,
 h2,
 h3,
 h4,
 h5,
 h6,
 th {
     font-size: 100%;
     font-weight: normal;
 }
 
 
 /*重置标题*/
 
 address,
 cite,
 dfn,
 var {
     font-style: normal;
 }
 
 
 /* 将斜体扶正 */
 
 code,
 kbd,
 pre,
 samp {
     font-family: 'courier new', courier, monospace;
 }
 
 
 /* 统一等宽字体 */
 
 small {
     font-size: 12px;
 }
 
 
 /* 小于 12px 的中文很难阅读,让 small 正常化 */
 
 ul,
 ol {
     list-style: none;
 }
 
 
 /* 重置列表元素 */
 
 button,
 input[type="submit"],
 input[type="button"] {
     cursor: pointer;
 }
 
 input[type="radio"],
 input[type="checkbox"],
 input[type="submit"],
 input[type="reset"] {
     vertical-align: middle;
     cursor: pointer;
     border: none;
 }
 
 
 /** 重置文本格式元素 **/
 
 a {
     text-decoration: none;
 }
 
 a:hover {
     text-decoration: underline;
 }
 
 a:focus {
     outline: 0;
 }
 
 sup {
     vertical-align: text-top;
 }
 
 
 /* 重置,减少对行高的影响 */
 
 sub {
     vertical-align: text-bottom;
 }
 
 
 /** 重置表单元素 **/
 
 legend {
     color: #000;
 }
 
 
 /* for ie6 */
 
 fieldset,
 img {
     border: 0;
 }
 
 
 /* img 搭车:让链接里的 img 无边框 */
 
 button,
 input,
 select,
 textarea {
     background: transparent;
     font-size: 100%;
     outline: 0;
 }
 
 
 /* 使得表单元素在 ie 下能继承字体大小 */
 
 
 /* 注:optgroup 无法扶正 */
 
 table {
     border-collapse: collapse;
     border-spacing: 0;
 }
 
 td,
 th {
     vertical-align: middle;
 }
 
 
 /** 重置表格元素 **/
 
 
 /* 重置 HTML5 元素 */
 
 article,
 aside,
 details,
 figcaption,
 figure,
 footer,
 header,
 hgroup,
 menu,
 nav,
 section,
 summary,
 time,
 mark,
 audio,
 video {
     display: block;
     margin: 0;
     padding: 0;
 }
 
 
 /*回复标签重置*/
 
 blockquote,
 q {
     quotes: none;
 }
 
 blockquote:before,
 blockquote:after,
 q:before,
 q:after {
     content: '';
     display: none;
 }

02 - 引入

// 在 main.js 中引入
import './assets/css/reset.css';

3. common.css

01 - 代码

// 清除浮动
.clearfix {
  *zoom: 1;
}

......

02 - 引入 

// 在 main.js 中引入
import './assets/css/common.css';

五、vue-router 路由配置

Vue3 之 Vue - Router_玄鱼殇的博客-CSDN博客

1. 安装

npm i vue-router

2. 配置

router文件夹 中的 index.js 中进行配置

// 1. 导入
import { createRouter, createWebHashHistory } from 'vue-router';

// 2. 创建路由对象
const router = createRouter({
  history: createWebHashHistory(),
  routes: [
    {
      path: '/',
      redirect: '/home'
    },
    {
      path: '/home',
      component: () => import('xxx/home.vue')
    }
  ]
});

// 3. 导出
export default router;

3. 引入 

// main.js

import { createApp } from 'vue';
import App from './App.vue';
// 1. 导入
import router from './router';

import 'normalize.css';
import './assets/css/reset.css';
import './assets/css/common.css';

// 2. 使用
createApp(App).use(router).mount('#app');

4. 使用 

在该用的地方加上 <router-view/>

六、pinia 状态管理

Vue3 之 Pinia - 状态管理_玄鱼殇的博客-CSDN博客

1. 安装

npm i pinia

2. 创建

stores文件夹 中创建 index.js

// 1. 导入
import { createPinia } from 'pinia'
// 2. 创建
const pinia = createPinia()
// 3. 导出
export default pinia

3. 引入

// main.js

import { createApp } from 'vue';
import App from './App.vue';
// 1. 导入
import router from './router';

import 'normalize.css';
import './assets/css/reset.css';
import './assets/css/common.css';

// 2. 使用
createApp(App).use(router).mount('#app');

4. 模块

stores文件夹 中创建 modules , 在其中创建模块

// 1. 导入
import { defineStore } from 'pinia';

// 2. 使用
const useDemoStore = defineStore('demoStore', {
  state: () => ({
    arrList: []
  }),
  actions: {},
  getters: {}
});

// 3. 导出
export default useDemoStore;

七、把代码推送到远程仓库

版本控制工具 之 Git_玄鱼殇的博客-CSDN博客

1. 初始化git仓库

git init

2. 配置 name 和 email

这里设定的是针对该仓库的配置

 

git config --local user.name 'xxxx'

git config --local user.email 'xxxx@qq.com'

3. 提交代码到本地

git add .

git commit -m 'feat: 项目初始化'

4. 生成远程仓库

5. 本地和远程连接

git remote add origin https://xxxxxx.git

git push -u origin master

八、项目正在开发中 🌰

1. 使用百度地图插件

01 - 注册并登录百度账号 百度地图开放平台 | 百度地图API SDK | 地图开发

02 - 成为开发者

        点击控制台

        填写资料进行注册​​​​​​​

03 - 创建应用

应用管理 >  我的应用

        创建应用

        获取AK

04 - 使用JavaScript API文档

jspopularGL | 百度地图API SDK

ps : 可查看hello world

        复制js代码,在index.html中引入

<!-- 这里使用了3.0的版本,把AK复制上去 -->
<script type="text/javascript" src="https://api.map.baidu.com/api?v=3.0&&type=webgl&ak=您的密钥">
</script>

        展示地图

<!-- ? 地图模块 -->
<template>
  <div class="detail-map-view">
    <!-- 1. 地图需要一个HTML元素作为容器 -->
    <div class="detail-map" ref="detailMapRef"></div>
  </div>
</template>

<script setup>
import { onMounted, ref } from 'vue';

const detailMapRef = ref(null);
onMounted(() => {
  // 2. 创建地图实例,传入地图容器,地图容器的ID为detailMapRef,即上面的<div>,地图容器必须是一个独立的div
  const map = new BMapGL.Map(detailMapRef.value);
  // 3. 创建点坐标,经度116.404,纬度39.915,可以通过百度地图API获取,也可以自己设置
  const point = new BMapGL.Point(116.404, 39.915);
  // 4. 初始化地图,设置中心点坐标和地图级别, 15为地图级别,数值越大,地图越精细
  map.centerAndZoom(point, 15);
  // 5. 创建标注,传入坐标
  var marker = new BMapGL.Marker(point);
  // 6. 将标注添加到地图中
  map.addOverlay(marker);
});
</script>

<style lang="less" scoped>
.detail-map-view {
  width: 100%;
  height: 300px;
  .detail-map {
    width: 100%;
    height: 100%;
  }
}
</style>

        效果

2. 监听页面的滚动

01 - 封装usePageScroll.js

import { ref, onActivated, onDeactivated, onMounted, onUnmounted } from 'vue';
import { throttle } from 'underscore';

export default function usePageScroll(domRef) {
  // 默认监听window窗口滚动事件
  let dom = window;
  // 是否滚动到底部
  const isArriveBottom = ref(false);

  // 滚动条滚动高度
  const scrollTop = ref(0);
  // 页面可视区域高度
  const scrollHeight = ref(0);
  // 页面总高度
  const clientHeight = ref(0);

  const scrollListen = throttle(() => {
    // 如果传入了domRef,则获取domRef的高度的值,否则获取window窗口的高度
    const heightData = domRef ? domRef.value : document.documentElement;

    // 获取滚动条滚动高度,已经滚动的距离
    scrollTop.value = heightData.scrollTop;
    // 获取页面总高度
    scrollHeight.value = heightData.scrollHeight;
    // window => 获取可见区域高度 (667)
    clientHeight.value = heightData.clientHeight;
    // const { scrollTop, scrollHeight, clientHeight } = document.documentElement;

    // 判断是否滚动到底部  =>  滚动高度 + 可视区域高度 >= 总高度时,加载更多
    if (scrollTop.value + clientHeight.value >= scrollHeight.value) {
      // 滚动到底部
      console.log('滚动到底部了');
      isArriveBottom.value = true;
    }
    // console.log(scrollTop.value, scrollHeight.value, clientHeight.value);
  }, 100);
  // 监听window窗口滚动事件
  onMounted(() => {
    // 如果传入了domRef,则监听domRef的滚动事件
    if (domRef) dom = domRef.value;
    dom.addEventListener('scroll', scrollListen);
  });
  onActivated(() => {
    dom.addEventListener('scroll', scrollListen);
  });
  // 取消监听window窗口滚动事件
  onUnmounted(() => {
    dom.removeEventListener('scroll', scrollListen);
  });
  onDeactivated(() => {
    dom.removeEventListener('scroll', scrollListen);
  });
  // 返回数据
  return { isArriveBottom, scrollTop, scrollHeight, clientHeight };
}

02 - 使用

<!-- ? 收藏模块 -->
<template>
  <div class="favor-view" ref="favorViewRef">
    <template v-for="item in 100">
      <div>列表数据:{{ item }}</div>
    </template>
  </div>
</template>

<script setup>
import usePageScroll from '@/hooks/usePageScroll';
import { ref, watchEffect } from 'vue';

const favorViewRef = ref(null);
const { scrollTop } = usePageScroll(favorViewRef);

watchEffect(() => {
  console.log(scrollTop.value);
});
</script>

<style lang="less" scoped>
.favor-view {
  height: 300px;
  overflow-y: auto;
}
</style>

03 - 效果 

3. 加载assets文件夹中的图片 

在vite中,加载图片须得转换一下

01 - 封装load_assets.js

export const getAssetURL = (image) => {
  // 参数一: 相对当前路径来配置路径
  // 参数二: 当前路径的URL
  return new URL(`../assets/img/${image}`, import.meta.url).href
}

02 - 使用

<!-- ? 底部tabber模块 -->
<template>
   <img  class="icon" :src="getAssetURL('tabbar/tab_favor.png')" />
</template>

<script setup>
import { getAssetURL } from '@/utils/load_assets';
</script>

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/408683.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

require.context()的用法详解

require.context&#xff08;&#xff09;的用法详解&#x1f334;require.context()的介绍&#x1f33a;用法一&#xff1a;在组件内引入多个组件&#x1f33c;用法二&#xff1a;在main.js中引入大量公共组件&#x1f342;用法三&#xff1a;使用插件注册全局组件&#x1f33…

axios+vue 请求时如何携带cookie

axiosvue 请求时如何携带cookie 1&#xff0c;当符合同源策略时&#xff0c;可以直接设置 document.cookie " 你要设置的内容 " mounted() {document.cookie "ioiopipoadiasdasdbasdbas"; // 非跨域传递cookie 直接设置cookie即可this.getData(); /…

Node.js安装,npm安装yarn步骤

第一步&#xff0c;首先安装npm npm是node.js下的包管理器&#xff0c;node.js的下载网址 Node.js 1.下载安装包后一路无脑点击next最后点击finish即可&#xff0c;安装完成之后打开文件夹就是以下目录。 2.在cmd窗口输入node -v、npm -v查看版本检查是否安装成功 一般完成以…

总结JS中常用的数组的方法大全

总结JS中常用的数组方法 JS中常用的数组方法总结 数组(Array)是一种复杂的数据类型&#xff0c;它属于Object(对象)类型&#xff0c;用来将一组数组合在一起&#xff0c;通过一个变量就可以访问一组数据。在使用数组时&#xff0c;经常会搭配循环语句使用&#xff0c;从而很方便…

Vue3+TS+Vite+Element Plus搭建后台管理系统

Vue3TSViteElement Plus搭建后台管理系统1、简介2、效果图3、技术栈4、项目目录5、setting.js(全局配置文件)6、路由router7、状态管理stores8、下载地址总结1、简介 该示例是vue3、typescript、vite、element plus搭建前端管理框架&#xff0c;主要模块分为&#xff1a;菜单、…

用 vite 构建 vue3 + TS 项目实战

目录 1、项目初始化 2、eslint 基础配置 3、配置 git commit hook 4、在开发和构建中进行代码规范校验 5、GitCommit规范 6、 Vite中的TS环境说明 7、Vue3 中 Ts 支持 8、Vue3中的script-setup语法 9、script-setup中的编译宏 10、配置转换JSX和TSX 11、初始化…

vue2计算属性computed

1.什么是计算属性 概念&#xff1a; 1.计算属性是vue的一个特性&#xff0c;此属性有计算能力&#xff0c;也就相当于一个函数。可以将计算结果缓存&#xff0c;作为一个属性使用。 特点&#xff1a; 1.要在 methods: { } 或者 computed&#xff1a; { } 中 &#xff0c;以方…

基于SpringBoot的医疗管理系统(Java毕业设计)

【辰兮要努力】&#xff1a;hello你好我是辰兮&#xff0c;很高兴你能来阅读&#xff0c;昵称是希望自己能不断精进&#xff0c;向着优秀程序员前行&#xff01; 博客来源于项目以及编程中遇到的问题总结&#xff0c;偶尔会有读书分享&#xff0c;我会陆续更新Java前端、后台、…

鲜花商城系统设计与实现(Java+Web+MySQL)

目 录 摘 要 I Abstract II 1 绪论 1 1.1 现状分析 1 1.2 研究意义 1 1.3 研究方法 1 2 系统的开发环境及技术简介 3 2.1 系统开发环境简介 3 2.2 系统开发技术简介 3 3 可行性研究 7 3.1 经济可行性 7 3.2 技术可行性 7 3.3 操作可行性 7 3.4 法律可行性 7 4 需求分析 9 4.1 …

vue+elementui中el-upload组件上传文件时,修改文件名,不用FormData

前言 今天在开发的时候&#xff0c;后端突然提了一个需求&#xff0c;因为特殊的文件上传不进文件服务器&#xff0c;所以后端问我能不能上传的时候给加个扩展名&#xff0c;本着只要逻辑没问题&#xff0c;都可以通过代码实现的理念&#xff0c;我说&#xff1a;“可以“”&a…

攻防世界WEB练习区(backup、cookie、disabled_button)

前言 作者简介&#xff1a;不知名白帽&#xff0c;网络安全学习者。 博客主页&#xff1a;https://blog.csdn.net/m0_63127854?typeblog 攻防世界专栏&#xff1a;https://blog.csdn.net/m0_63127854/category_11983747.html 网络安全交流社区&#xff1a;https://bbs.csdn.ne…

uniApp h5项目通过命令行打包,并生成指定路径、文件名称

需求&#xff1a;想要自动化部署uni项目&#xff0c;平常的uni项目是通过可视化构建&#xff0c;导致我们的自动部署成了半自动&#xff0c;非常不爽&#xff0c;于是就找到了下面这种方法 首先&#xff0c;用hb新建一个项目 然后&#xff0c;通过cli新建一个项目 文档 vue c…

禁止 input 自动填充

禁止 input 自动填充 在编写 Form 表单样式的时候&#xff0c;修改自动填充后的 input 样式是很麻烦甚至不可行的&#xff0c;而且还有一些不需要自动填充的场景。 浏览器根据保存数据时表单控件的 type 和 name 去匹配。 常用的就是 type 为 password&#xff0c;name 为 em…

Android 设置Padding和Margin(动态/静态)

一、什么是padding&#xff0c;什么是margin&#xff1f; 在Android界面开发时&#xff0c;为了布局更加合理好看&#xff0c;很多时候会用上Padding和Margin&#xff0c; padding和margin是什么呢&#xff1f;即内边距和外边距&#xff1b; 某个View指定为padding是针对该V…

vue制作一个好看的网页

1.安装并配置node.js (见本人博客-node.js) 2.建好的项目目录如下 build: 用来存放项目构建脚本 config: 存放项目的一些基本配置信息&#xff0c;最常用的就是端口转发 node_modules:这个目录存放项目的所有依赖&#xff0c;由npm install 下载来的文件 src:存放项目的源…

Vue设置浏览器小图标(ICON)

Vue设置浏览器小图标 当我们使用浏览器做开发时&#xff0c;我们能希望浏览器标签页能显示自己的logo小图标&#xff0c;这个是怎样设置的呢&#xff1f; 第一步&#xff1a;准备logo图片信息 找到自己的logo&#xff0c;通过图片在线转换格式&#xff0c;转换成32*32的ico为…

css关于文本溢出

处理思路 1&#xff09;给需要做溢出处理的文本元素设置width或者max-width 2&#xff09;超出部分省略 overflow:hidden 3) 文本溢出处理方式 text-overflow: ellipsis | clip | 自定义字符 如&#xff1a;“_” “.” 4) 设置文本不换行 white-space: nowrap 单行文本溢出 …

Rust开发WebAssembly在Html和Vue中的应用【后篇】

【建议先看】继上一篇【Rust开发WebAssembly在Html和Vue中的应用】遗留下来的问题 Rust开发WebAssembly在Html和Vue中的应用_一码超人的博客-CSDN博客 本文讲述Vue2与H5版uniapp如何引入rust webassembly的应用流程 在上一文中末尾&#xff0c;我说过vue2在引入胶水js后执行…

关于vue2与vue3

Vue组件之间通信方式有哪些 vue是组件化开发框架&#xff0c;所以对于vue应用来说组件间的数据通信非常重要。 1. 组件通信常用方式有以下8种: props $emit/$on $children/$parent $attrs/$listeners ref $root eventbus vuex 注意vue3中废弃的几个API 在vue3中废除$c…

前端实现tab栏切换,这么常见的案例你学会了吗?

&#x1f4cb; 个人简介 &#x1f496; 作者简介&#xff1a;大家好&#xff0c;我是阿牛&#xff0c;全栈领域新星创作者。&#x1f61c;&#x1f4dd; 个人主页&#xff1a;馆主阿牛&#x1f525;&#x1f389; 支持我&#xff1a;点赞&#x1f44d;收藏⭐️留言&#x1f4d…