【前端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

相关文章

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本