vue3后台管理系统

vite构建vue3项目

  1. npm create vite@latest,再回车
  2. 按要求写下项目名;manage-app
  3. 选择vue,再回车
  4. 选择javascript,在回车
  5. cd manage-app,到该项目目录下,回车
  6. 安装依赖:npm install,再回车
  7. 启动项目:npm dev
  8. main.js文件的改变:
createApp(App).mount('#app')
//上面那行改为下面这行,一样的,
const app=createApp(App)
app.mount('#app')

项目中其他需求的引入

1. element-plus引入

1. 全部引入:

  • 在终端安转:npm install element-plus --save
  • main.js文件引入:
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'

const app=createApp(App)
app.use(VueElementPlus)
app.mount('#app')

  • 使用:直接在组件里编写element代码即可

2. 按需引入:

  • 在终端安转:npm install element-plus --save
  • 在终端安装插件:npm install -D unplugin-vue-components unplugin-auto-import
  • 在 vite.config.ts文件引入:
//引入部分
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import {
    ElementPlusResolver } from 'unplugin-vue-components/resolvers'

//plugins数组部分加入
  plugins: [
    AutoImport({
   
      resolvers: [ElementPlusResolver()],
    }),
    Components({
   
      resolvers: [ElementPlusResolver()],
    }),
  ],
  • 使用:直接在组件里编写element代码即可

3. 手动引入:

  • 在终端安转:npm install element-plus --save
  • 终端安装:npm install unplugin-element-plus
  • 在 vite.config.ts文件引入:
//引入部分
import ElementPlus from 'unplugin-element-plus/vite'

//plugins数组部分加入
   plugins: [ElementPlus()],
  • 使用:在使用element的组件里引入具体需要的插件,比如需要引入按钮插件则需要加这段代码:
<script>
import {
    ElButton } from 'element-plus'

export default defineComponent({
   
    component:{
    ElButton}
})
</script>

2. vue3引入路由

  1. 终端安装:npm install vue-router -S
  2. 新建文件:src / router / index.js:文件配置如下
import {
   createRouter,createWebHashHistory} from 'vue-router' 

const routes=[
    {
   
        path:'/',
        redirect:'/home',
        component:()=>import('../views/MainApp.vue'),
        children:[
            {
   
                path:'/home',
                nsme:'home',
                component:()=>import('../views/home/HomeApp.vue')
            }
        ]
    }
]

const router=createRouter({
   
    history:createWebHashHistory(),
    routes
})

export default router
  1. main.js文件引入
import router from './router'

const app=createApp(App)
app.use(router)
app.mount('#app')
  1. 使用:在具体的组件中需要导入
import {
   useRouter} from 'vue-router' //导入1
export default {
   
  setup() {
   
     let router=useRouter()//声明2
//下面可以配置方法进行路由跳转
     }
}
  1. 需要显示路由组件的地方添加<router-view></router-view>

3. element-plus图标的引入和使用

  • 在终端安转:npm install element-plus --save
  • 终端安转:npm install @element-plus/icons-vue
  • main.js引入:
import * as ElementPlusIconsVue from '@element-plus/icons-vue'

const app = createApp(App)

for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
   
  app.component(key, component)
}

app.mount('#app')

静态引入图标

  • 直接点击想要的图标图案,就可以复制相关代码
//例如加号图标
<el-icon><Plus /></el-icon>

动态引入图标

 <!-- 遍历菜单栏-->
    <el-menu-item :index="item.path" v-for="item in noChildren()" :key="item.path">
    
        <!-- 根据遍历得到的item,动态引入图标 -->
       <component class="icons" :is="item.icon"></component>
       
    </el-menu-item>

4. 引入less

  • 终端引入less:npm install less-loader less --save-dev

5. 基础样式引入

  • 在src/assets新建文件夹less
  • 在less文件夹新建reset.less文件,这个是全局样式
  • 在less文件夹新建index.less文件,里面只写@import './reset.less';
  • 在main.js中引入index.js文件 ,import './assets/less/index.less'

6. vuex的引入

    1. 终端安装:npm install vuex -S
    1. 新建文件:src / store / index.js,文件配置如下
import {
   createStore} from 'vuex'
export default createStore({
   
   //里面配置数据方法等
    state:{
   //数据
    
    } ,
    mutations:{
   //修改数据的方法

    },
})
    1. 在main.js文件引入
import store from './store/index.js'

const app=createApp(App)
app.use(store)
app.mount('#app')
    1. 使用:使用vuex数据和方法的组件需要引入
<script>
import {
    useStore } from "vuex";
export default defineComponent ({
   
  setup() {
   
  //定义store
  let store = useStore();
  
  function handleCollapse(){
   
    //调用vuex中的mutations中的updateIsCollapse方法
     store.commit("updateIsCollapse")
  }
    return {
   
       handleCollapse
    };
  },
});
</script>

工具类的使用

一、mock的使用

  • 本地mock 的使用

  1. 终端安转:npm install mockjs
  2. 新建文件:src / api / mockData / home.js(home.js表示的是home组件的mock数据)---------文件配置如下:
export default{
   
   getHomeData:()=>{
       //导出home 的数据
       return {
   
           code:200,
          data:{
   
           tableData :[
               {
   
                 name: "oppo",
                 todayBuy: 500,
                 monthBuy: 3500,
                 totalBuy: 22000,
               },
               {
   
                 name: "vivo",
                 todayBuy: 300,
                 monthBuy: 2200,
                 totalBuy: 24000,
               },
               {
   
                 name: "苹果",
                 todayBuy: 800,
                 monthBuy: 4500,
                 totalBuy: 65000,
               },
               {
   
                 name: "小米",
                 todayBuy: 1200,
                 monthBuy: 6500,
                 totalBuy: 45000,
               },
               {
   
                 name: "三星",
                 todayBuy: 300,
                 monthBuy: 2000,
                 totalBuy: 34000,
               },
               {
   
                 name: "魅族",
                 todayBuy: 350,
                 monthBuy: 3000,
                 totalBuy: 22000,
               },
             ]
          }
       }
   }
}
  1. 再建文件:src / api / mock.js ,这个文件引入所有的mock数据,并且全部导出。----------- 文件配置如下
//导入mockjs
import Mock from 'mockjs'  

//导入home的数据
import homeApi from './mockData/home' 

//拦截请求,两个参数,第一个参数是设置的拦截请求数据的路径,第二个参数是对应数据文件里该数据的方法a
Mock.mock('/home/getData',homeApi.getHomeData)
  1. 引入:在mian.js文件里引入mock--------如下引入
import './api/mock.js'
  1. 使用:在响应的组件上使用
async function getTableList(){
   
  await axios.get("/home/getData").then((res)=>{
   
          tableData.value=res.data.data.tableData
   })
}
onMounted(()=>{
   
  //调用getTableList()方法
getTableList()
})
  • 线上fastmock 的使用

  1. 点击“+”,创建项目,
    在这里插入图片描述
  2. 得到项目的根路径
    在这里插入图片描述
  3. 点击新增接口
    在这里插入图片描述
  4. 编辑接口路径以及返回的数据
    在这里插入图片描述
  5. 最终得到请求拦截地址,与请求得到的数据
    在这里插入图片描述
  6. 在组件里的使用:
//axios请求table列表的数据,并且将请求来的数据赋值给tableData
 async function getTableList(){
   
    await axios
    //该路径为线上mock的接口根路径与对应数据请求的路径的拼接。
    .get("https://www.fastmock.site/mock/d32d92a0e177cd10b103d38a2b74d3ec/api/home/getTableData")
    .then((res)=>{
   
        if (res.data.code == 200){
   
            //请求成功之后在进行渲染
             tableData.value=res.data.data
           }
     })
}
onMounted(()=>{
   
    //调用getTableList()方法
getTableList()
})

二、二次封装axios

  1. 二次封装axios的原因:处理接口请求之前或接口请求之后的公共部分

  2. 终端安装:npm install axios -S

  3. 在新建文件(环境配置文件):src /config / index.js------文件如下

/**
 * 环境配置文件
 * 一般在企业级项目里面有三个环境
 * 开发环境
 * 测试环境
 * 线上环境
 */
// 当前的环境赋值给变量env
const env = import.meta.env.MODE || 'prod'

const EnvConfig = {
   
  //1、开发环境
  development: {
   
    baseApi: '/api',
    //线上mock的根路径地址
    mockApi: 'https://www.fastmock.site/mock/d32d92a0e177cd10b103d38a2b74d3ec/api',
  },
  //2、测试环境
  test: {
   
    baseApi: '//test.future.com/api',
    mockApi: 'https://www.fastmock.site/mock/d32d92a0e177cd10b103d38a2b74d3ec/api',
  },
  //3、线上环境,企业才会用,
  pro: {
   
    baseApi: '//future.com/api',
    mockApi: 'https://www.fastmock.site/mock/d32d92a0e177cd10b103d38a2b74d3ec/api',
  },
}

export default {
   
  env,
  // mock的总开关,true则项目的所有接口调用的是mock数据
  mock: true,
  ...EnvConfig[env]//结构
}
  1. 新建文件:src / api /request.js-------文件如下
import axios from 'axios'
import config from '../config'
//错误提示
import {
    ElMessage } from 'element-plus'
const NETWORK_ERROR = '网络请求异常,请稍后重试.....'


//创建axios实例对象service
const service=axios.create({
   
    //根路径为config里的index.js文件里的开发环境的baseApi
    baseURL:config.baseApi
})


//在请求之前做的一些事情,request
service.interceptors.request.use((req)=>{
   
    //可以自定义header
    //jwt-token认证的时候
    return req//需要return出去,否则会阻塞程序
})
 


//在请求之后做的一些事情,response
service.interceptors.response.use((res)=>{
   
    console.log(res)
    //解构res的数据
    const {
    code, data, msg } = res.data
     // 根据后端协商,视情况而定
    if (code == 200) {
   
    //返回请求的数据
    return data
  } else {
   
    // 网络请求错误
    ElMessage.error(msg || NETWORK_ERROR)
     // 对响应错误做点什么
    return Promise.reject(msg || NETWORK_ERROR)
  }
})



//封装的核心函数
function request(options){
   
    //默认为get请求
    options.methods=options.methods || 'get'
    if (options.method.toLowerCase() == 'get') {
   
        options.params = options.data
      }

            // 对mock的处理
  let isMock = config.mock  //config的mock总开关赋值给isMock
  if (typeof options.mock !== 'undefined') {
    //若组件传来的options.mock 有值,单独对mock定义开关
    isMock = options.mock  //就把options.mock 的值赋给isMock
  }
   // 对线上环境做处理
  • 5
    点赞
  • 43
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Vue 3是一种流行的JavaScript框架,用于构建用户界面。它提供了一些强大的工具和功能,使开发人员能够轻松地构建现代、高效的Web应用程序。 对于后台管理系统Vue 3提供了许多有用的功能和组件,使开发人员能够快速构建出功能丰富、易于维护的系统。以下是一些常见的Vue 3后台管理系统的特点和技术: 1. 组件化开发:Vue 3使用组件化的开发模式,使得代码可复用,并且更易于维护和扩展。你可以将不同的功能模块封装成独立的组件,然后在应用中进行组合和重用。 2. 路由管理:Vue Router是Vue 3的官方路由管理器,它允许你通过定义路由来管理应用的导航。你可以根据路由配置来渲染不同的组件,并且支持动态路由和嵌套路由。 3. 状态管理:Vue 3使用Vuex进行状态管理,它提供了一个集中式的存储机制,用于在应用程序中管理共享状态。你可以在任何组件中访问和修改这些状态,并且支持异步操作和插件扩展。 4. UI库和组件:Vue 3有许多优秀的UI库和组件库可供选择,例如Element Plus、Ant Design VueVuetify等。这些库提供了丰富的UI组件和样式,可用于构建美观和交互丰富的后台管理系统。 5. 状态响应性:Vue 3引入了响应式API,使得数据的变化可以自动地反映在用户界面上。你可以将数据绑定到模板中,并在数据发生变化时自动更新视图。 总之,使用Vue 3开发后台管理系统可以帮助你更快速、高效地构建出现代化的用户界面。它提供了丰富的工具和功能,使得开发过程更加简单和愉快。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值