【前端52_Vue】工程化:快速安装脚手架、创建项目、安装插件、开发需要知道的:静态文件的引入、路径转换规则、CSS:预处理器、Scoped、数据访问相关:数据模拟、代理

本文主要是介绍【前端52_Vue】工程化:快速安装脚手架、创建项目、安装插件、开发需要知道的:静态文件的引入、路径转换规则、CSS:预处理器、Scoped、数据访问相关:数据模拟、代理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 工程化 Vue cli
    • 简介
    • 快速开发
      • 全局安装 vue/cli-service-global
      • 单个 vue 的预览
    • 创建项目
      • 命令行创建
      • Vue UI
    • 安装插件
    • 开发需要知道的
      • 静态文件的引入
      • 路径转换规则
      • 何时使用绝对 / 相对路径?
      • 使用 `public` 文件夹的注意事项(尽量不用)
    • CSS 相关
      • 预处理器
      • 自动化导入样式
      • Scoped CSS
      • 深度选择器
        • scoped 中的穿透
        • `scss` 中使用穿透
      • CSS Module
    • 数据访问相关
      • 数据模拟
      • 代理
    • 写在最后


工程化 Vue cli

简介

工程化,它的全称叫做:command line interface

引入工程化的目的是:让项目有系统性的工程管理、优化、以及压缩等

你想啊,如果是单 html 这样的文件去做前端项目的话,会有很多弊端

  • 如果是团队开发,你改这别人改哪儿的,合并代码的时候一堆报错,导致邻里不和谐
  • 维护起来十分复杂,一坨屎谁写的,删掉!
  • 不好优化,比方说压缩一下静态资源啦,压缩生产代码啦等等

所以,工程化应运而生


快速开发

全局安装 vue/cli-service-global

要想起一个 vue 项目,我们需要安装全局依赖

npm install -g @vue/cli-service-global

单个 vue 的预览

我们可以使用 vue servevue build 命令对单个 *.vue 文件进行快速原型开发
请添加图片描述


创建项目

命令行创建

安装完Vue cli脚手架之后,可以在终端通过如下命令创建项目

vue create 你的项目名

在这里插入图片描述

自定义有如下选项(以后可能更多)

是否用 babel、是否用TSPWA、路由管理、状态管理、CSS 预编译器、代码风格以及格式化工具、单元测试、端对端测试

这些都是比较常用的,不清楚的可以百度一下
在这里插入图片描述

选择完之后,回车即可,创建完项目之后是这个样子,可以看到一个项目的概览
在这里插入图片描述

Vue UI

或者通过页面交互的形式来创建项目,在终端里输入如下命令

vue ui 

然后再 create 菜单中配置你的项目的一些变化,跟命令行中的设置差不多,配置好后,点击创建项目即可

请添加图片描述

同时终端会有变化
在这里插入图片描述

创建好项目后,浏览器会自动弹出 Vue uidashbord (仪表盘),页面大概长这个样子

在这里插入图片描述

可以通过 inspect 检查的功能查看 vue cli 脚手架 自动给我们配置的 webpack 配置

在这里插入图片描述


安装插件

Vue CLI 使用了一套基于插件的架构。插件可以修改 webpack 的内部配置,也可以向 注入命令。在项目创建的过程中,绝大部分列出的特性都是通过插件来实现的。

如果你想在一个已经被创建好的项目中安装一个插件,可以使用 vue add 命令。

这里举个例子:

vue add router

在这里插入图片描述


开发需要知道的

静态文件的引入

开发时难免遇到静态资源,如何引入呢?

当你在 JavaScriptCSS*.vue 文件中使用相对路径 (必须以 . 开头) 引用一个静态资源时,该资源 将webpack 处理

后面跟的随机数是文件的 hashwebpack 静态处理了这些资源并打包

在这里插入图片描述

如果想用绝对地址,也就是服务器下的资源,可以把静态资源放到 public 文件夹下,这样就不会被 webpack 打包处理了。

在这里插入图片描述

路径转换规则

  • 如果 URL 是一个绝对路径 (例如 /images/foo.png ),它将会被保留不变。

    <img alt="Vue logo" src="/assets/logo.png">
    <img alt="Vue logo" src="http://image.xx.com/logo.png">
    
  • 如果 URL. 开头会作为一个相对模块请求被解释并基于文件系统相对路径

    <img alt="Vue logo" src="./assets/logo.png">
    
  • 如果 URL~ 开头会作为一个模块请求被解析。这意味着你甚至可以引用 Node 模块中的资源(也就是说node_module 里的东西也能拿出来引用,并不常见):

    <img src="~some-npm-package/foo.png">
    
  • 如果 URL@ 开头会作为一个模块请求被解析。Vue CLI 默认会设置一个指向 src 的别名 ,记为@ (你可以理解 @ 就是 src 文件夹的路径,它也是相对路径,所以会被 webpack 处理)。

    import Hello from '@/components/Hello.vue'
    

何时使用绝对 / 相对路径?

通过 webpack 的处理并获得如下好处:

  • 脚本和样式表会被压缩且打包在一起,从而避免额外的网络请求。
  • 文件丢失会直接在编译时报错,而不是到了用户端才产生 404 错误。
  • 最终生成的文件名包含了内容哈希,因此你不必担心浏览器会缓存它们的老版本。

如下情况考虑使用 public 文件夹

  • 你需要在构建输出中指定一个固定的文件名字。
  • 你有上千个图片,需要动态引用它们的路径。
  • 有些库可能和 webpack 不兼容,除了将其用一个独立的

使用 public 文件夹的注意事项(尽量不用)

  • 如果你的应用没有部署在域名的根部,那么你需要为你的 URL 配置 publicPath 前缀

    官网的 vue cli 说明

    以下举个栗子🌰
    在这里插入图片描述

  • public/index.html 等通过 html-webpack-plugin 用作模板的 HTML 文件中,你需要通过 <%= BASE_URL %> 设置链接前缀
    在这里插入图片描述

  • 在模板中,先向组件传入 BASE_URL

    data () {return {publicPath: process.env.BASE_URL}
    }
    

    然后这样使用

    <img :src="`${publicPath}my-image.png`">
    

这里举个例子

在这里插入图片描述


CSS 相关

预处理器

如果你用了其他的 css 预处理语言,但是没有安装,就会报错啊~

报错图片如下:

在这里插入图片描述

安装一下

# Sass
npm install -D sass-loader node-sass
# Less
npm install -D less-loader less
# Stylus
npm install -D stylus-loader stylus

不过我安装 node-sass 安装失败了,问题不详(我猜测应该是 scss-loader 版本的问题),解决办法是重新创建个项目,哪里会让你选择 css 预编译器,

自动化导入样式

自动化导入样式文件 (用于颜色、变量、mixin 等),可以使用 style-resources-loader 这个依赖,我们先安装以下

npm i -D style-resources-loader

然后再 vue.config.js 中配置一下

// vue.config.js
const path = require("path");
function addStyleResource(rule) {rule.use("style-resource").loader("style-resources-loader").options({patterns: [path.resolve(__dirname, "./src/styles/imports.scss")],});
}module.exports = {lintOnSave: false,chainWebpack: (config) => {const types = ["vue-modules", "vue", "normal-modules", "normal"];types.forEach((type) =>addStyleResource(config.module.rule("scss").oneOf(type)));},
};

生效的样子如下:
在这里插入图片描述

Scoped CSS

<style> 标签有 scoped 属性时,它的 CSS 只作用于当前组件中的元素

其原理是通过使用 PostCSS 来实现以下转换:

<template><div class="red" data-v-f3f3eg9>hi</div>
</template><style>
.red[data-v-f3f3eg9] {color: red;
}
</style>

下图是我做的实验啊。
在这里插入图片描述

在这里插入图片描述

深度选择器

深度选择器是在 scoped 生效的

scoped 中的穿透

可以通过 >>> 穿透,意思就是:在父组件控制子组件的元素样式。其原理应该是交集选择器,证据如下:

在这里插入图片描述
使用场景

  • 修改三方的样式库,比方说 element UI
scss 中使用穿透

说是有两种方法,但是 /deep/ 这种不好使,查了一下应该是 sass-load 版本的问题

<style scoped lang="scss">
#app {// 第 1 种方法/deep/ a {color: rgb(196, 50, 140)}// 第 2 种方法::v-deep a {color: rgb(196, 50, 140)}
}
</style>

在这里插入图片描述

CSS Module

CSS Modules 是一个流行的,用于模块化和组合 CSS 的系统。 vue-loader 提供了与 CSS Modules 的 集成,可以作为模拟 scoped CSS 的替代方案。

首先这样写 style,需要用 module 来声明出来

<style module lang="scss">
.red {color: #f00;
}
.bold {font-weight: bold;
} </style>

模板中通过 $style.xx 访问

<a :class="$style.red">awesome-vue</a>
<a :class="{[$style.red]:isRed}">awesome-vue</a>
<a :class="[$style.red, $style.bold]">awesome-vue</a>

JavaScript 中也可以访问

<script>
export default {
created () {
// -> "red_1VyoJ-uZ"
// 一个基于文件名和类名生成的标识符 console.log(this.$style.red)
} }
</script>

例子如下:

在这里插入图片描述


数据访问相关

数据模拟

在这里插入图片描述

代理

做代理,浏览器是看不到的,但并不是说没有做这个代理,我们仍然访问的是本地 8080 端口,然而找不到这个静态资源,于是去代理服务器寻找

在这里插入图片描述

在这里插入图片描述

写在最后

今天突然发现一下多了 9 个粉丝,我的天,什么情况,我买水军了?

好兄弟们有啥想法可以提出来哦,有用的话点个赞让我知道一下也行啊,感激不尽 desu。

请添加图片描述

这篇关于【前端52_Vue】工程化:快速安装脚手架、创建项目、安装插件、开发需要知道的:静态文件的引入、路径转换规则、CSS:预处理器、Scoped、数据访问相关:数据模拟、代理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/976060

相关文章

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

Mysql如何将数据按照年月分组的统计

《Mysql如何将数据按照年月分组的统计》:本文主要介绍Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql将数据按照年月分组的统计要的效果方案总结Mysql将数据按照年月分组的统计要的效果方案① 使用 DA

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

如何解决mmcv无法安装或安装之后报错问题

《如何解决mmcv无法安装或安装之后报错问题》:本文主要介绍如何解决mmcv无法安装或安装之后报错问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mmcv无法安装或安装之后报错问题1.当我们运行YOwww.chinasem.cnLO时遇到2.找到下图所示这里3.

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas

CSS Padding 和 Margin 区别全解析

《CSSPadding和Margin区别全解析》CSS中的padding和margin是两个非常基础且重要的属性,它们用于控制元素周围的空白区域,本文将详细介绍padding和... 目录css Padding 和 Margin 全解析1. Padding: 内边距2. Margin: 外边距3. Padd

CSS will-change 属性示例详解

《CSSwill-change属性示例详解》will-change是一个CSS属性,用于告诉浏览器某个元素在未来可能会发生哪些变化,本文给大家介绍CSSwill-change属性详解,感... will-change 是一个 css 属性,用于告诉浏览器某个元素在未来可能会发生哪些变化。这可以帮助浏览器优化

CSS去除a标签的下划线的几种方法

《CSS去除a标签的下划线的几种方法》本文给大家分享在CSS中,去除a标签(超链接)的下划线的几种方法,本文给大家介绍的非常详细,感兴趣的朋友一起看看吧... 在 css 中,去除a标签(超链接)的下划线主要有以下几种方法:使用text-decoration属性通用选择器设置:使用a标签选择器,将tex