搭建项目前端系统基础架构

news2024/9/28 13:21:19

Vue是什么

Vue 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。目前市面上有很多基于Vue重新封装的各种前端UI框架,集成比较容易,如Element,iView等,另外它能让团队书写用js更容易并且简化了js。上手Vue.js是相当容易的。它的源码有着很高的可读性,如果你需要仅用他的文档便可入门,你不必使用任何额外的库。如果需要可以和jQuery协同工作。他有许多的插件,但并非必须。通过几个方面说一下Vue的优势:

  • 渲染性能:

通过虚拟dom减少对真实dom的操作,Vue实现的权重要轻的多。所以渲染用户界面的时候,Vue的速度会更快一点。Vue几乎不需要手工优化,

  • 更新性能:

当一个组件的状态发生变化时,组件的依赖关系在它的渲染期间被自动跟踪,因此系统准确地知道哪些组件实际上需要重新渲染。这就意味着在更新方面,Vue也是快的。

  • 规模方面:

Vue 的路由库和状态管理库都是由官方维护支持且与核心库同步更新的

  • 文档方面:

详尽的中文文档

  • 结构方面:

Vue单文件由模版、脚本、样式,层次分明,长得像 HTML

总体来说轻量级框架、简单易学、双向数据绑定、组件化、视图、数据和结构的分离、虚拟DOM、运行速度快。这就是选择这个框架的理由。

安装Vue环境

  • 安装Node.js会自动安装好node以及包管理工具npm(注意:安装Node建议使用下图中推荐的版本14.16.1)
  • Node.js官方网址为:Node.js — Download

当前环境中安装Node.js 14.16.1版本,如想使用其他版本或最新版本请自行下载安装,但不建议更换node或npm版本,可能会发生版本兼容问题。

使用VSCode创建基于Vue的项目

  • 全局安装 cnpm
[root@client ~]# npm install -g cnpm@6.2.0 -registry=https://registry.npm.taobao.org

  • 在控制台命令窗口中依次执行如下命令,创建Vue项目:

1) 全局安装 vue-cli

[root@client ~]# cnpm install -g @vue/cli

2) 创建一个基于Vue 2的新项目(注意:由于vue create命令在创建项目时对命名为特殊要求,所以这里创建的项目名为“kongguan_web”,后期如果对项目名称为特殊要求,可以在项目创建完成后手动修改即可。)

[root@client ~]# vue create kongguan_web

使用 方向键 选择“Manually select features”,然后回车进入下一步

根据自己的需要选择所需要安装的功能,使用 空格键 选择或者取消选择,然后回车进入下一步

使用 方向键 选择Vue的版本为 2.x ,然后回车进入下一步

然后输入“Y”,并回车

使用 方向键 选择“Sass/SCSS (with dart - sass)”并回车

使用 方向键 选择“In package.json”并回车

回车后,项目开始创建,等待完成即可

3)进入项目目录

[root@client ~]# cd kongguan_web/

4)使用npm安装依赖(注意:npm默认使用国外镜像,可能会出现连接失败的问题,如出现连接失败可将npm命令切换成cnpm命令 例如:cnpm install

[root@client kongguan_web]# cnpm install

  • 使用VSCode打开Vue项目(当前环境已经安装,如果没有安装,请从https://update.code.visualstudio.com/1.52.1/linux-rpm-x64/stable下载自行安装)

1)在桌面双击“Visual Studio Code”图标,打开VSCode

2)点击“File”菜单,选择“Open Folder”,找到并打开创建的kongguan_web

3)在项目中打开终端命令行窗口

4)在创建好的项目下运行(注意:npm默认使用国外镜像,可能会出现连接失败的问题,如出现连接失败可将npm命令切换成cnpm命令

[root@client kongguan_web]# npm run serve

5)Vue项目已经启动,打开浏览器访问8080端口即可:

至此,我们已经可以开发Vue的项目了,接下来我们需要先了解一个系统架构目录设计,然后再根据功能需求完成开发工作即可。

系统架构目录讲解

  • 民航系统前端Vue项目的目录如下:

目录/文件说明
build项目构建(webpack)相关代码
config配置目录,包括端口号等。
node_modulesnpm 加载的项目依赖模块
src

这里是我们要开发的目录,基本上要做的事情都在这个目录里。里面包含了几个目录及文件:

  • assets: 放置一些图片,如logo等。
  • components: 将各个模块的页面都写在这个文件夹下,分开模块和功能。
  • App.vue: 项目入口文件,我们也可以直接将组件写这里,而不使用 components 目录。
  • main.js: 项目的核心文件。
src/api

根据各个功能模块,封装了其请求后台的方法;

src/assets

图片存放地址

src/components

文件中使用的组件

src/router

项目路由器设置

src/store

菜单、token等设置

src/utils

存放公用设置

src/views

页面主要编写目录

static静态资源目录,如图片、字体等。
favicon.ico系统iCon
index.html首页入口文件,你可以添加一些 meta 信息或者系统名等。
package.json项目包配置文件。
README.txt项目的说明文档
  • 具体介绍一下src下业务模块的目录结构:

目录/文件说明
src/api

根据各个功能模块,封装了其请求后台的方法

src/assets

存放图片等静态资源文件

src/components

项目中使用的组件,也包含所有的模块功能,通过模块将页面的功能分开,例如:login、home等

echart/AirPortCount/目录:各空点统计报表

echart/SectorCallStaturation/目录:“各扇区通话饱和度”ECharts报表

echart/SectorFlightInfo/目录:“扇区架次数动态展示”ECharts报表

echart/YearWarningSummary/目录:年度警告摘要报表

AirLine.vue文件:显示“动态航线图”组件

Delay.vue文件:显示“指挥航空公司架次月延误率占比”组件

Pager.vue文件:分页组件

Section.vue文件:显示“扇区航班数”组件

WarnStatistice.vue文件:显示“年度告警区域统计”组件

src/routerVue项目的路由器设置
index.js 文件:Vue页面请求的路由设置、导航守卫(例如:判断用户是否登陆)等
src/store

菜单、token等设置

modules/menu.js 文件:菜单设置

index.js 文件:Token设置

src/utils

存放通用的工具和公共检验工具等

src/views

页面主要编写目录

/Home/Index.vue文件:前端的“首页”

/Home/map.vue文件:前端的“航班实时监控”页

/Layout/Header.vue文件:

/Layout/Layout.vue文件:

/Login/Login.vue文件:

/redirect/index.vue文件:

src/main.js

Vue系统入口,主方法:

  • The Vue build version to load with the `import` command
  • (runtime-only or standalone) has been set in webpack.base.conf with an alias
  • 在src/main.js中可以实现:将自定义组件导入Vue、定义响应拦截器、定义请求拦截器、拦截重复请求等操作

5、创建项目前端系统基础架构

  • 按照上面的目录结构,先创建一部分空目录和空文件,为后续的前端开发提供一个基本环境,基本结构如下:

  • 删除项目的node_modules目录和package-lock.json文件

  • 修改vue.config.js文件,增加"lintOnSave:false",目的是忽略命名不规范检查,内容如下:
const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
  transpileDependencies: true,
  lintOnSave: false
})
  • 修改 package.json文件,配置项目的依赖包,内容如下:
{
  "name": "kongguan_web",
  "version": "0.1.0",
  "private": true,
  "scripts": {
    "dev": "vue-cli-service serve --open",
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "lint": "vue-cli-service lint"
  },
  "dependencies": {
    "core-js": "^3.8.3",
    "vue": "^2.6.14",
    "axios": "^0.19.2",
    "echarts": "^4.9.0",
    "element-ui": "^2.13.2",
    "moment": "^2.29.1",
    "node-sass": "^4.14.1",
    "sass-loader": "^7.3.1",
    "v-distpicker": "^1.2.2",
    "vee-validate": "^2.2.13",
    "vue-baidu-map": "^0.21.22",
    "vue-multiselect": "^2.1.6",
    "vue-router": "^3.0.6",
    "vue2-datepicker": "^2.12.0",
    "vuex": "^3.1.1",
    "xlsx": "^0.15.1"
  },
  "devDependencies": {
    "@babel/core": "^7.12.16",
    "@babel/eslint-parser": "^7.12.16",
    "@vue/cli-plugin-babel": "~5.0.0",
    "@vue/cli-plugin-eslint": "~5.0.0",
    "@vue/cli-service": "~5.0.0",
    "eslint": "^7.32.0",
    "eslint-plugin-vue": "^8.0.3",
    "vue-template-compiler": "^2.6.14",
    "@vue/eslint-config-standard": "^4.0.0",
    "babel-eslint": "^10.0.1",
    "mockjs": "^1.0.1-beta3",
    "node-sass": "^4.14.1",
    "sass-loader": "^7.3.1"
  },
  "eslintConfig": {
    "root": true,
    "env": {
      "node": true
    },
    "extends": [
      "plugin:vue/essential",
      "eslint:recommended"
    ],
    "parserOptions": {
      "parser": "@babel/eslint-parser"
    },
    "rules": {
      "no-unused-vars":"off"
    }
  },
  "browserslist": [
    "> 1%",
    "last 2 versions",
    "not dead"
  ]
}
  • 强制清理 npm 缓存
[root@client kongguan_web]# npm cache clean --force
  • 为当前项目添加依赖包,使用npm install 或 npm i 命令
[root@client kongguan_web]# npm install --unsafe-perm=true --allow-root

注意:

1)如果以root身份运行npm install命令安装依赖包时,--unsfe-perm参数的默认值为false,以非root身份运行时,--unsfe-perm参数的默认值为true。

2)如果--unsfe-perm的值设置为true可在运行包脚本时抑制UID/GID切换。如果--unsfe-perm的值为false,则以非root用户身份安装将失败。

3)所以,如果以root身份运行npm install命令安装依赖包时,建议使用【npm install --unsafe-perm=true --allow-root】命令。

执行npm install命令后,可以看到如上图所示的结果,实际每个人的环境显示的结果可能略有不同。

  • 运行kongguan_web项目
[root@client kongguan_web]# npm run serve

可以看到项目正常运行。

注意:如果前面使用【 npm run serve】运行kongguan_web项目时报以下错误:

产生原因:文件监视程序的系统产生了限制,达到了默认的上限,需要增加限额。查看限额可以使用如下命令:

[root@client kongguan_web]# cat /proc/sys/fs/inotify/max_user_watches

解决办法:可以临时增加限额

[root@client kongguan_web]# sudo sysctl fs.inotify.max_user_watches=524288 
[root@client kongguan_web]# sudo sysctl -p

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

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

相关文章

暗光增强——IAT网络推理测试(详细图文教程)

IAT模型由两个独立的分支组成,局部分支用于像素调整,并输出两个用于加法和乘法的特征图。全局分支用于全局调整并输出颜色矩阵和gamma值,全局分支受DETR启发,网络通过动态查询学习的方式更新颜色矩阵和gamma值。整个模型只有超过9…

Day63:WEB攻防-JS应用算法逆向三重断点调试调用堆栈BP插件发包安全结合

目录 前置知识 JS调试分析 JS分析调试结合Burp JS分析调试知识点: 1、JavaScript-作用域&调用堆栈 2、JavaScript-断点调试&全局搜索 3、JavaScript-Burp算法模块使用 前置知识 JS加密数据走向 浏览器调试 1、作用域:(本地&全…

Infineon_TC264智能车代码初探及C语言深度学习(二)

本篇文章记录我在智能车竞赛中,对 Infineon_TC264 这款芯片的底层库函数的学习分析。通过深入地对其库函数进行分析,C语言深入的知识得以再次在编程中呈现和运用。故觉得很有必要在此进行记录分享一下。 目录 ​编辑 一、代码段分析 NO.1 指向结构体…

Python 合并两张图片

发现一个很有意思的图片处理包PIL,可以将两张图片合并成一张,而且很好看。代码如下 from PIL import Image# 打开两张图片 image1 Image.open("1.jpg").convert("RGBA") image2 Image.open("2.jpg").convert("RGB…

Siamese Network(孪生神经网络)详解

Siamese和Chinese有点像。Siam是古时候泰国的称呼,中文译作暹罗。Siamese也就是“暹罗”人或“泰国”人。Siamese在英语中是“孪生”、“连体”的意思,这是为什么呢?十九世纪泰国出生了一对连体婴儿,当时的医学技术无法使两人分离…

设置浏览器显示小于12px以下字体

问题 我们在项目开发过程中有时候会遇到设计师给的小于12px的字体,IE、火狐浏览器、移动端等小于12px的字号大小还是可以正常显示的,但是谷歌浏览器上显示字体最小为12px,css设置font-size:10px,运行代码显示结果仍然…

Linux:kubernetes(k8s)Deployment的操作(13)

创建deployment 命令 kubectl create deploy nginx-deploy --imagenginx:1.7.9 再去使用以下命令分别查询 ubectl get deploy kubectl get replicaset kubectl get pod 他是一个层层嵌套的一个关系 首先是创建了一个 deploy 里面包含着replicaset replicaset里面含有…

网络原理(网络协议初识)

目录 1.网络通信基础 1.1IP地址 1.2端口号 1.3认识协议 1.4五元组 1.5 协议分层 2.TCP/IP五层(或四层)模型 2.1网络设备所在分层 2.2网络分层对应 3.封装和分用 1.网络通信基础 网络互连的目的是进行网络通信,也即是网络数据传输&#…

[Kali] 安装Nessus及使用

在官方网站下载对应的 Nessus 版本:Download Tenable Nessus | TenableDownload Nessus and Nessus Managerhttp://www.tenable.com/products/nessus/select-your-operating-system这里选择 Kali 对应的版本 一、安装 Nessus 1、下载得到的是 deb 文件,与

solana 入门 1

solana-co-learn Solana 开发学习笔记(一)——从 Hello World 出发 安装开发环境 windows下环境配置 wsl First start with installing WSL on your system. wsl --install wsl安装Ubuntu 列出可用的分发版 wsl.exe --list --online显示: 以下是可安装的有效…

LLM推理框架Triton Inference Server学习笔记(一): Triton Inference Server整体架构初识

官方文档查阅: TritonInferenceServer文档 1. 写在前面 这篇文章开始进行大语言模型(Large Language Model, LLM)的学习笔记整理,这次想从Triton Inference Server框架开始,因为最近工作上用到了一些大模型部署方面的知识, 所以就快速补充了…

SpringBoot配置资源文件自动热更新

1、修改启动配置 On update action 和 On frame deactivation 添加 update classes and resources 配置 2、IDEA菜单栏File->setting->Build,Execution,Deployment->Compiler 勾选Build project automatically 3、禁用Thymeleaf的缓存 在开发环境中,通过…

点云处理ransac算法

参考资料: 点云处理入门 RANSAC & ICP with PCL Demo - 知乎 ransac是什么? 随机采样一致算法(RANdom SAmple Consensus)RANSAC。该算法可以从一组观测数据中(包含离群点),查找出符合某个数…

圈子社交系统-多人语音-交友-陪玩-活动报名-商城-二手论坛-源码交付,支持二开!

圈子小程序适用于多种场景,涵盖了各个领域的社交需求。以下是一些常见的适用场景: 兴趣社区: 用户可以加入自己感兴趣的圈子,与志同道合的人一起讨论交流,分享经验和知识。 行业交流: 各个行业可以建立自…

【C++map和set容器:AVL树、红黑树详解并封装实现map和set】

[本节目标] map和set底层结构 AVL树 红黑树 红黑树模拟实现STL中的map和set 1.底层结构 前面对map/multimap/set/multiset进行了简单的介绍,在其文档介绍中发现,这几个容器有个 共同点是:其底层都是按照二叉搜索树来实现的,但…

【C++】string的底层剖析以及模拟实现

一、字符串类的认识 C语言中,字符串是以\0结尾的一些字符的集合,为了操作方便,C标准库中提供了一些str系列的库函数, 但是这些库函数与字符串是分离开的,不太符合OOP的思想,而且底层空间需要用户自己管理&a…

算法空间复杂度计算

目录 空间复杂度定义 影响空间复杂度的因素 算法在运行过程中临时占用的存储空间讲解 例子 斐波那契数列递归算法的性能分析 二分法(递归实现)的性能分析 空间复杂度定义 空间复杂度(Space Complexity)是对一个算法在运行过程中临时占用存储空间大…

深入理解JAVA异常(自定义异常)

目录 异常的概念与体系结构 异常的概念: 异常的体系结构: 异常的分类: 异常的处理 防御式编程 LBYL: EAFP: 异常的抛出 异常的捕获 异常声明throws try-catch捕获并处理 finally 面试题: 异常的处理流程 异常处…

【数据结构与算法】:插入排序与希尔排序

🔥个人主页: Quitecoder 🔥专栏: 数据结构与算法 欢迎大家来到初阶数据结构的最后一小节:排序 目录 1.排序的基本概念与分类1.1什么是排序的稳定性?1.2内排序与外排序内排序外排序 2.插入排序2.1实现插入排序2.3稳定性…

谈谈你对Java平台的理解?

从你接触 Java 开发到现在,你对 Java 最直观的印象是什么呢?是它宣传的 “Write once, run anywhere”,还是目前看已经有些过于形式主义的语法呢?你对于 Java 平台到底了解到什么程度?请你先停下来总结思考一下。 今天…