webpack手动配置一个vue3项目

news2024/11/14 13:25:19

感觉学webpack和vite比登天还难啊,所以只是止步于能用和一些基础的配置比如proxy等等。因为自己是看培训班视频入的门,有些东西不是非常清楚(话说清楚了不还是个前端),关于如何拓展自己的职业宽度,每个人有自己的想法,个人认为可以心安理得地依赖于脚手架的相关配置。但是有些基础流程还是要懂的。我会以一个门外汉的角度去描述项目搭建的过程(本来也就是个门外汉)

一、webpack和vite这类的工具到底干了啥

首先是压缩你的js代码,压缩成你看不懂的一坨。

其次它能让你自己配置如何打包,也就是代码分离,比如两个js文件都依赖a.js,难道还要引入两次a.js,那肯定是打包到一个共同的依赖里面。

都是为了尽量减小打包后文件的大小,文件小就是速度快。

最后,它还给你了一个本地服务器,打包后的效果直接在本地呈现,并且还实现了热重载(打包一次呈现一次,不用每次修改之后都重新打开服务器),当然这个服务器还可以帮你做跨域,开发期间转发你的请求(服务器之间通信不必遵守同源策略)

以上就是我一个门外汉的理解。

二、配置一个项目究竟要考虑些什么

1.npm的使用

npm就是个包管理,你要通过npm去引用网上下载来的包,比如vue等等,各种loader也是通过npm下载的,可能最常见的命令就是npm install,然后最常见的两个生成的文件就是package.json、package-lock.json。

前者就是一个包目录,记着你下载了哪些东西的json大对象,下面是我这个项目配置好的package.json

{
  "name": "wp_for_vue",
  "version": "1.0.0",
  "description": "vue多页面打包时间",
  "main": "main.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "dev": "webpack serve --progress --config ./webpack.config.js"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "@babel/cli": "^7.21.5",
    "@babel/core": "^7.21.8",
    "@babel/preset-env": "^7.21.5",
    "babel-loader": "^9.1.2",
    "css-loader": "^6.7.3",
    "html-webpack-plugin": "^5.5.1",
    "sass": "^1.62.1",
    "sass-loader": "^13.2.2",
    "style-loader": "^3.3.2",
    "vue-loader": "^17.1.1",
    "vue-template-compiler": "^2.7.14",
    "webpack": "^5.82.1",
    "webpack-cli": "^5.1.1",
    "webpack-dev-server": "^4.15.0"
  },
  "dependencies": {
    "pinia": "^2.0.36",
    "vue": "^3.2.47",
    "vue-router": "^4.2.0"
  }
}

可以看见一些关于作者和项目名称的信息,当然最重要的是这三个部分:

dependencies下面的内容指的是网页运行时需要的依赖,这里的话就是pinia、vue、vue-router,这些内容是会被打包的,因为没有这些内容网页不能运转,我们在npm下载的时候会写下“npm install 包名 --save”,--save的后缀就是暗示这些会被归到dependencies的内容中。

devDependencies,与之相对应的,这就是开发时所需要的依赖,比如里面的sass-loader,这个是用来解读sass文件的,要把sass文件转换成简单的css,那么在打包之后就没啥用了,就是个工具,是不会被打包的。“npm install 包名 --save-dev”,这样的话包就会被放在devDependencies之中。

script,这就是个npm 命令,比如npm run dev这个指令,就是用npm去运行 script当中的dev命令,如下

"scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "dev": "webpack serve --progress --config ./webpack.config.js"
  },

这个dev命令就是先webpack打包,再打开本地服务器,使用的配置是webpack.config.js中的配置。

当然还有一个文件package-lock.json,这个文件的作用就是为了“lock”住版本号,简单说,上面的两种依赖都是有版本的,比如有些项目就是vue2写的,你vue3有些写法是跑不通的,package-lock.json中就会记录下,这个项目要用vue2。npm install会根据这个文件下载对应的版本的依赖

2.项目结构

也就是src之中的内容,见下图

 和脚手架,配置的一样,很明显这是一个单页应用程序,也就是一个spa,不是洗浴的那个spa啊,其实也就是一个html,以后通过动态请求数据来渲染新的内容。

至于里面的数据如何配置,如果不懂的话需要好好看看官网了。

3.babel

这个其实我其实不是很懂,babel的主要功能就是将es6之后的写法,转换成es5的内容,有些浏览器似乎是不能显示es6之后的js的写法。可以通过babel.config.json的文件配置

{
    "presets": [
        [
            "@babel/preset-env",
            {
                "targets": {
                    "browsers": [
                        "last 2 versions"
                    ]
                }
            }
        ]
    ]
}

 这个配置我网上抄来的,完全的配置需要看官网。

4..gitignore文件

git仓库会将项目内容传入远程仓库,但是有些内容不需要上传,因此需要一个配置文件来ignore忽视他们,比如说node_modules里面的内容,这么多上传干嘛,依赖可以根据package-lock.json自己下载嘛,如下是我们的配置,同样也是vue-cli项目里直接复制来的

# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

我们可以从中窥见,node_modules模块,打包之后的dist,ide的配置,log日志之类的文件是不用上传的。

5.webpack.config.js

终于到我们的最终部分了,先看一下我的简单配置

const path = require('path')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const { VueLoaderPlugin } = require('vue-loader')//vue-loader

module.exports = {
    mode: 'development', // 环境模式
    module: {
        rules: [
            {
                test: /\.vue$/,
                loader: 'vue-loader'//所有vue结尾的文件都要经过这个loader
            },
            {
                test: /\.scss$/,//用来处理css文件
                use: [
                    'style-loader',
                    'css-loader',
                    'sass-loader'
                ]
            },
            {
                test: /\.js$/, //把js文件变成es5以下的版本
                exclude: /node_modules/, // 不编译node_modules下的文件
                loader: 'babel-loader'
            }
        ]
    },
    entry: path.resolve(__dirname, './src/main.js'), // 打包入口
    output: {
        path: path.resolve(__dirname, 'dist'), // 打包出口
        filename: 'js/[name].js', // 打包完的静态资源文件名
        clean: true,//每次打包都会删除dist里面旧的内容
    },
    plugins: [
        new HtmlWebpackPlugin({
            template: path.resolve(__dirname, './index.html'), // 我们要使用的 html 模板地址
            filename: 'index.html', // 打包后输出的文件名
            title: '手搭 Vue 开发环境' // index.html 模板内,通过 <%= htmlWebpackPlugin.options.title %> 拿到的变量
        }),
        new VueLoaderPlugin() //vue-loader插件
    ],
    devServer: {
        // 配置展示用服务器了
        client: {
            overlay: true,//出现错误的时候显示全屏覆盖,就是vue那个大框
            reconnect: 3,//告诉 dev-server 它应该尝试重新连接客户端的次数,就写个三次,事不过三吗
        },
        compress: true,//启用资源压缩
        hot: true,//启用热重载
        host: '127.0.0.1',//host地址
        port: 996,//页面端口
        open: true,//打包完成后自动打开页面,我其实不是很喜欢这个配置
    }
}

我们将其分为以下几个部分来分析:

出口入口:

  entry: path.resolve(__dirname, './src/main.js'), // 打包入口
    output: {
        path: path.resolve(__dirname, 'dist'), // 打包后的文件放的位置
        filename: 'js/[name].js', // 打包完的静态资源文件名
        clean: true,//每次打包都会删除dist里面旧的内容,从而方便形成新文件
    },

loader:

webpack只能处理js和json,其他如css之类的内容需要loader处理,我这里的引入了vue、css、scss、style、babel的loader,具体用来处理处理对应的文件,具体的功能都写在上面。

插件:

也就是webpack的plugin,webpack也需要一些插件来完成其他工作,比如上面的HtmlWebpackPlugin,就是为最后生成的index.html文件生成模版的,指定其title等等。我们经常使用的dev server其实也是一个插件。

本地服务器的配置:

在devServer之中,具体可以看上面,写的比较详细了其实,规定了地址端口,是否热重载等等。

三、如何进行配置

我看到很多文章都会按照步骤,教你一步步配置,其实如果你看懂了上面的文章,就会发现大题配置一下很简单

1.创建包管理仓库,aka “npm init -y”

2.安装依赖,npm install 包名 --save的方式安装package.json文件下的dependencies,npm intall 包名 --save-dev的方式安装package.json文件下devDependencies中的开发依赖

3.配置babel、.gitignore和webpack.config.js,在package.json的script中增加dev命令

重点是配置webpack中的出入口、loader和服务器

4.初始化src中的具体内容,也就是vue的初始化等等,这个应该很早就会解除了

5.npm run dev,看看服务器有没有运起来

四、我们如何看待webpack之类工具

放弃学生思维,先跑起来再优化,试图在短期内把文档看透,我是没那个能力,这里还没有ts和多页面呢,ts的话还有一个config文件,所以说依赖脚手架的配置也没啥错

看职业规划去决定熟练程度,一边有人喊着前端“已死”,一边有人想着怎么在前端琢磨“茴”的四种写法,看你自己如何判断

长期主义,程序员作为一种职业,大部分人是前后端都写的,不应该恐惧webpack,所以我决定差不多得了,最后看一眼远方的项目结构吧

 

 

 

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

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

相关文章

Qt消息的理解

分析 信号是什么&#xff0c;信号与槽(Signals&Slot)是QT编程的基础&#xff0c;也是Qt的一大创新。因为有了信号与槽的编程机制&#xff0c;在Qt中处理界面各个组件的交互操作变得更加直观和简单。 信号(signal)就是特定下被发射的事件。 槽就是对信号响应的函数&#xf…

如何解决MySQL limit深分页问题

1、limit深分页为什么会变慢&#xff1f; 先看下表结构&#xff1a; CREATE TABLE account (id int(11) NOT NULL AUTO_INCREMENT COMMENT 主键Id,name varchar(255) DEFAULT NULL COMMENT 账户名,balance int(11) DEFAULT NULL COMMENT 余额,create_time datetime NOT NULL …

机器视觉是如何实现激光焊缝追踪系统

随着工业科学技术的发展&#xff0c;机器更换的地方越来越多&#xff0c;现在一些焊接工作交给了机器&#xff0c;其核心技术是&#xff1a; 激光束追踪传感器通过计算&#xff0c;将激光放大后投影到被测量物的表面&#xff0c;其反射光透过高质量的光学系统并投影到成像矩阵…

二叉堆讲解

二叉堆讲解 大顶堆和小顶堆 从二叉堆的结构说起&#xff0c;它是一棵二叉树&#xff0c;并且是完全二叉树&#xff0c;每个结点中存有一个元素&#xff08;或者说&#xff0c;有个权值&#xff09;。 堆性质&#xff1a;父亲的权值不小于儿子的权值&#xff08;大根堆&#x…

AI制作视频——mov2mov以及inpaint

背景 AI制作视频的几种思路 1.从零开始生成&#xff1a;清华的cogview&#xff0c;runway gen-1、gen-2&#xff0c;微软的女娲 这个思路&#xff0c;就是认为可以通过文字描述的方式把视频画面描述出来&#xff0c;通过对文本-视频帧内容-视频内容的数据对的平行语料的学习…

微软限制我们使用Windows系统了,怎么办?

正如中国工程院院士倪光南所说&#xff0c;操作系统的成功与否&#xff0c;关键在于生态系统&#xff0c;需要搭建起完整的产业链上各个主体共生的生态体系。 当前我国国产操作系统市场发展很快&#xff0c;相比技术和市场突破&#xff0c;真正需要解决的问题是如何把生态建好…

Jvm-08a.类加载器

类与类加载器 对于任意一个类&#xff0c;都必须由加载它的类加载器和这个类本身一起共同确立其在Java虚拟机中的唯一性&#xff0c;每一个类加载器&#xff0c;都拥有一个独立的类名称空间。 通俗的讲就是比较两个类是否"相等"&#xff0c;只有在这两个类是由同一…

设计模式实战 | 迭代器模式 | 分词器

1、场景 假设有下面这样一个字符串属性&#xff0c; 代表着属性逐级调用&#xff0c; 我们需要解析出每一个字段属性方便我们后续进行业务处理。 String properties "school.teacher[语文].student[3].user[4].english.score";2、传统写法 遍历该属性字符串然后不…

ChatGLM-6B模型结构组件源码阅读

一、前言 本文将介绍ChatGLM-6B的模型结构组件源码。 代练链接&#xff1a;https://huggingface.co/THUDM/chatglm-6b/blob/main/modeling_chatglm.py 二、激活函数 torch.jit.script def gelu_impl(x):"""OpenAIs gelu implementation."""r…

k8s系列(三)——kubernetes架构及部署

引入 在正式引入K8s之前&#xff0c;我们先来看一张图 虚拟化技术演历路径可分为三个时代&#xff1a; 物理机时代&#xff0c;多个应用程序可能跑在一台物理机器上&#xff1b; 这种方式会造成一旦某个服务出现溢出或者未知的错误&#xff0c;从而影响机器上所有服务的正常…

C++ -- 红黑树封装set和map

文章目录 1. 红黑树概念和性质1.1 概念1.2 性质1.3 实例1.4 分析 2. 节点定义3. 插入操作4. 检测5. 红黑树代码6. 红黑树实现set和map6.0 类设计图6.1 红黑树包装复用6.2 红黑树实现set6.3 红黑树实现map6.4 剖析代码6.4.1 如何复用6.4.2 如何区分set和map比较方式6.4.3 set和m…

如何用appuploader上架

转载&#xff1a;下载和安装appuploader IOS开发工具官网地址 Appuploader home -- A tool improve ios develop efficiency such as submit ipa to appstore and manage ios certificate 最新版本已经优化了没支付688给apple的账号登录流程&#xff0c;无需再安装其他软件。…

SDK案例配置记录

目前的极简配置 注意事项 默认的属性配置中&#xff0c;大多采用环境变量的形式&#xff0c;方便不同设备通用 比如“常规”->“输出目录”为 $(SolutionDir)..\bin\win_msvc2017$(Platform)\$(Configuration)\案例运行前的配置&#xff08;除MwBatchSimPlugin&#xff0…

如何评估用户需求的价值?关键看4方面

一、需求本身是否有价值 评估一个需求是否有价值&#xff0c;主要是通过以下几个方面&#xff1a;需求的产生源、需求产生的时机&#xff08;情景价值&#xff09;、需求如何产生&#xff08;问题解决价值&#xff09;、需求如何解决&#xff08;解决需求&#xff09;。 在情景…

web安全学习笔记【网络安全】

前言 本文简单记录一下我学习 Web 安全方面的笔记。 本文不涉及 IIS、Windows 和 SqlServer 的安全管理与配置&#xff0c;尽量只谈编程相关的安全问题。 这个 Web 安全学习路线&#xff0c;整体大概半年左右&#xff0c;具体视每个人的情况而定。 &#xff08;上传一直很模…

支持AI算法定制的4G摄像头模组解决方案

随着科技的不断发展&#xff0c;现在人们对于监控摄像头的需求越来越高&#xff0c;但是市场上的大多数摄像头组件都是标准化的&#xff0c;很难满足不同应用场景的需求。 不过&#xff0c;现在有了这款支持AI算法定制的4G摄像头模组解决方案&#xff0c;这个问题就完美的解决了…

shell脚本教程

目录 一、shell历史 二、执行脚本 三、基本语法 3.1变量 3.1.1变量的分类 3.1.2删除变量 3.2文件名代换&#xff08;Globbing&#xff09; 3.3命令代换 3.4算术代换 3.5转义字符 3.6单引号 3.7双引号 四、Shell脚本语法 4.1条件测试 4.2分支 4.2.1if/then/elif…

重磅!用友荣登全球5强

近日&#xff0c;全球权威信息技术研究和顾问公司Gartner发布《Market Share: All Software Markets, Worldwide&#xff0c;2022》报告&#xff0c;用友在EAM&#xff08;资产管理&#xff09;市场再创新高&#xff0c;市场占有率位居全球第五位&#xff0c;亚太第一位&#x…

quic详解

目录 一 http简介 二 quic协议详解 1 重传机制 2 流量控制 3连接迁移 一 http简介 http0.9 1991年发布&#xff0c; 没有header&#xff0c;功能非常简单&#xff0c;只支持GET http1.0 1996年发布&#xff0c;明文传输安全性差&#xff0c;header特别大。它相对0.9有以…

postgres_exporter 部署

目录 - 下载地址- 配置环境变量- 启动vim ./start.shvim ./stop.shqueries.yaml - 配置prometheus - 下载地址 https://github.com/prometheus-community/postgres_exporter/releases - 配置环境变量 - 启动 因启动前需要配置环境变量后再进行启动 运行如下语句&#xff1a…