vue3 + vite4.0 开发项目(PC端和移动端共用一套代码)

vue3 + vite4.0 开发项目(PC端和移动端共用一套代码)

做公司官网,为了实现PC端与移动端自适应的问题,决定使用 vue 开发项目,写两套代码,并***采用路由控制,加载PC端代码还是移动端代码,通过屏幕宽度大小来判断加载相应端的代码***。
其中产生的一些问题及难点在这里进行一些记录。

1、创建两套代码的文件夹

创建两套代码的文件夹,其中包含移动端、PC端的所有的内容。
在这里插入图片描述
其中的 index.vue 文件是用来存放 的,用于展示路由组件。
在这里插入图片描述

2、创建一个文件用于展示两个index.vue组件

创建一个文件用于引入并展示两个index.vue组件,也就是用于判断是pc端、还是移动端的组件进行展示。我是放在了 views 文件夹下,直接创建了一个 index.vue 文件。
其中 devices 是用于获取当前的窗口状态,‘pc’则是PC端,‘mobile’是移动端。
在这里插入图片描述
代码如下:

<script setup>
import pc from './pc/index.vue'
import mobile from './mobile/index.vue'
import {
    deviceStore } from '@/stores/deviceStore'
const devices = deviceStore()
</script>

<template>
  <div>
    <pc v-if="devices.device === 'pc'" />
    <mobile v-if="devices.device === 'mobile'" />
  </div>
</template>
<style lang="scss" scoped>
</style>

3、状态管理 devices

这里主要是使用 pinia 创建了一个状态管理,用于存储,可以全局使用。
在这里插入图片描述
代码如下:

// 管理设备数据
import {
    defineStore } from 'pinia'
import {
    ref } from 'vue'
export const deviceStore = defineStore('devices', () => {
   

  const device = ref('pc') // 默认是PC端,====》 PC端:pc、移动端:mobile

  /**
   * 切换设备类型
   * @param {*} type 
   */
  const handleToChangeDevice = (type) => {
   
    device.value = type
  }

  return {
   
    device,
    handleToChangeDevice
  }
})

4、两套路由

将PC端代码与移动端代码分别写在两套路由表里面,默认的 index.js 中如如这两套路由表,并且默认展示 PC 端的路由。
在这里插入图片描述
其中移动端的路由表,大概如下:

export const mobile = [
  {
   
    path: '/',
    name: 'mobile',
    component: () => 
对于Vue 3 + Vite + TypeScript实现PC适配,你可以遵循以下步骤: 1. 安装Vue 3Vite:首先,确保你已经安装了Node.jsnpm。然后运行以下命令来全局安装Vite创建一个新的项目: ``` npm install -g create-vite create-vite my-app --template vue-ts cd my-app npm install ``` 2. 安装依赖:进入项目目录后,使用npm安装所需的依赖项,包括一些可能用到的UI库或CSS框架,例如Element Plus、Ant Design等等。 3. 创建布局组件:在src目录下创建一个Layout组件,作为整个应用的主要容器。这个组件将包含头部、侧边栏主体内容。 4. 使用路由:在src目录下创建一个router目录,并在其中创建一个index.ts文件。在这个文件中,你可以使用Vue Router创建路由配置,并在主要布局组件中使用<router-view>来渲染不同的页面。 5. 创建页面组件:在src目录下创建一个views目录,并在其中创建各个页面的组件。每个页面组件将包含该页面的内容。 6. 创建样式文件:你可以使用CSS、SCSS或者其他CSS预处理器来编写样式。在src目录下创建一个styles目录,并在其中创建一个全局样式文件。 7. 实现响应式布局:Vue 3引入了Composition API,你可以使用`reactive``ref`等函数来处理响应式布局。根据不同的屏幕尺寸,你可以使用媒体查询或CSS框架的栅格系统来调整布局。 8. 添加适配代码:你可以使用Vue的全局mixin或自定义指令来添加适配代码。在适配代码中,你可以根据屏幕尺寸或其他条件,动态改变样式、布局或内容。 以上是一个大致的步骤,你可以根据实际需求项目的复杂性进行调整。希望对你有所帮助!如果有任何问题,请随时提问。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值