webpack4手动搭建Vue项目

news2024/11/13 9:37:52

小满视频

  • 很多解释使用通义灵码搜的,通义灵码的搜索结果也是有错误的
  • 全程使用pnpm包管理工具,和npm的用法基本一样

学习总结
1. 多看看webpack官网
2. webpack的作用:配置一堆东西,达到运行程序的目的
3. 无论什么东西都转成js,然后插入到一个空空的html文件中运行
4. webpack就是个管理者,管理着一堆loader,一堆loader的作用就是把自己负责的东西弄成js

手动搭建Vue项目,使用webpack4

  • 手动构建webpack基本环境
    • 1. 初始化node项目
    • 2. 生成TypeScript项目
    • 3. 安装webpack
    • 4. 安装webpack-cli
    • 5. 安装webpack-dev-server
    • 6. 安装html-webpack-plugin
    • 7. 安装Vue
    • 8 安装vue-loader
    • 9 安装clean-webpack-plugin
    • 10. 结果
    • 小结:
      • 项目目录树
      • 各文件代码
        • 1. webpack.config.js
        • 2. tsconfi.json
        • 3. package.json
        • 4. main.ts
        • 5. end.d.ts
        • 6. App.vue
        • 7. /public/index.html
  • webpack.config.js中的其他配置项
    • 1. resolve解析器
      • alias:设置别名
      • extensions:省略后缀名
    • 2. plugin 插件
    • 3. devServer 网络/服务相关配置
    • 4. stats 控制台信息如何显示
    • 5. module.rules配置预加载器
    • 6. 外部扩展(Externals)

手动构建webpack基本环境

webpack官网链接

1. 初始化node项目

  1. 初始化一个 Node.js 项目,并生成一个 package.json 文件
pnpm init

执行命令后自动创建package.json文件,内容如下:

{
  "name": "webpack-demo", 项目的名称
  "version": "1.0.0",项目的版本号
  "description": "",项目的简短描述
  "main": "index.js",项目的主入口文件
  "scripts": {项目的脚本命令,如测试脚本。
    "test": "echo \"Error: no test specified\" && exit 1"定义了一个简单的测试命令,当运行 npm test 时,会输出错误信息并退出。
  },
  "keywords": [],项目的关键词列表,用于搜索和分类
  "author": "",项目的作者信息
  "license": "ISC"项目的许可类型
}

2. 生成TypeScript项目

  1. 安装typescript
pnpm i typescript -g
  1. 生成 TypeScript 项目,和项目的初始配置文件 tsconfig.json
tsc --init
  • tsconfig.json内容
{
  "compilerOptions": {
  	  target: es2016  设置目标 ECMAScript 版本
	  module: commonjs 指定模块系统。这里的 "commonjs" 表示使用 CommonJS 模块系统。
	  strict: true 启用所有严格的类型检查选项
	  esModuleInterop: true 启用 ES 模块与 CommonJS 模块之间的互操作性。这里的 true 表示启用此功能。
	  skipLibCheck: true 是否跳过类型声明文件的检查。这里的 true 表示跳过类型声明文件的检查。
	  forceConsistentCasingInFileNames: true 强制要求文件名大小写一致。这里的 true 表示启用此功能。
  }
}

-查看全局安装的插件的安装位置

npm config get prefix

3. 安装webpack

webpack官网

  • webpack.config.js文件中所有的配置项都是webpack管理的

  • 安装webpack

pnpm add webpack -D
  • Webpack 是一个非常流行的 JavaScript 模块打包器,用于将现代前端应用中的各种资源(如 JavaScript、CSS、图片等)打包成一个或多个浏览器可以加载的文件。Webpack 提供了一种强大的方式来组织和管理前端资源,使其易于维护和优化。
  • 根目录创建webpack.config.js文件
  • webpack.config.js中配置打包的入口和出口文件及打包后文件的路径
const config = {
    mode: 'development', // 开发模式
    entry: "./src/main.ts", // 入口文件
    output: {
        filename: "[fullhash].js", // 输出文件名
        path: path.resolve(__dirname , "dist") // 输出路径
    },
}
module.exports = config;

__dirname: 表示当前配置文件所在的目录。
‘dist’: 表示输出文件所在的子目录名。
path.resolve: 用于将相对路径转换为绝对路径。

4. 安装webpack-cli

pnpm add webpack-cli -D
  • package.json文件中配置打包命令
  "scripts": {
    "bulid": "webpack",
	...
	...
  },
  • webpack-cli 是 Webpack 提供的命令行工具,用于在命令行中执行 Webpack 相关的操作。webpack-cli 主要完成以下几项工作:

    1. 解析和处理命令行参数:webpack-cli 负责解析用户在命令行中输入的参数,包括配置文件路径、打包模式、插件等信息。通过解析这些参数,webpack-cli 确定如何执行 Webpack 相关的操作。
    2. 载入并执行 Webpack 配置:webpack-cli 负责读取并解析指定的 Webpack 配置文件(通常是 webpack.config.js)。通过读取配置文件,webpack-cli 知道如何进行模块打包、资源处理等操作。
    3. 调用 Webpack API:通过调用 Webpack 提供的 API,webpack-cli 将用户输入的参数和配置转化为具体的 Webpack 打包操作。webpack-cli 可以执行 Webpack 的构建、开发服务器启动、打包分析等功能。
    4. 提供辅助功能:除了执行 Webpack 操作外,webpack-cli 还提供了一些辅助功能,比如生成 Webpack 相关的配置文件模板、帮助命令、插件等,帮助开发者更方便地使用 Webpack。
  • 在命令行输入:pnpm run devpnpm run build 时,通过webpack-cli执行webpack中的命令,并使用相应的配置,比如:webpack.config.js中打包的入口和出口等配置项

  • 不安装此插件也可以运行webpack,只不过可能需要很多复杂的命令

5. 安装webpack-dev-server

  • 作用:
    webpack-dev-server 是一个基于 Node.js 的本地开发服务器,它可以与 Webpack 一起使用,为开发者提供实时重新加载和热模块替换等功能。它能够自动监听文件更改,并在文件发生变化时重新编译并刷新浏览器,从而极大地提高了开发效率。
pnpm add webpack-dev-server -D

6. 安装html-webpack-plugin

  • 作用:
    用于生成 HTML 文件,并自动注入 Webpack 打包后的 JavaScript 和 CSS 文件。这个插件可以帮助你轻松地管理和自动化 HTML 文件的生成过程,确保每次构建后都能得到最新的 HTML 文件。
pnpm add html-webpack-plugin -D
  • package.json文件中配置运行命令
  "scripts": {
    "dev":"webpack-dev-server --open",
	...
	...
  },

–open:自动打开浏览器

  • 在webpack.config.js中配置此插件:
// 导入html-webpack-plugin
const HtmlWebpackPlugin = require("html-webpack-plugin");
    plugins: [
        new HtmlWebpackPlugin({
          template: './public/index.html', // 指定模板文件
          filename: 'index.html',        // 输出文件名
          inject: 'body'                 // 注入的位置
        })
      ],

7. 安装Vue

pnpm add vue -D
  • main.ts
import { createApp } from "vue";
import App from "./App.vue";

createApp(App).mount("#app");
  • App.vue
<template>
  <div>
      test
  </div>
</template>

<script setup lang=ts>
    
</script>

<style scoped lang="scss" >
</style>

  • 新建vue.d.ts文件,main.ts中使用了import App from "./App.vue";代码,在编译时TypeScript 不认识.vue文件,在此声明.vue文件的类型
declare module "*.vue"{
    import type {DefineComponent} from 'vue'
    const component:DefineComponent<{},{},any>
    export default component
}
  • .d.ts文件是 TypeScript 定义文件的一种。在 TypeScript 中,.d.ts 文件用于提供类型定义,以便 TypeScript 编译器可以理解未包含类型信息的 JavaScript 代码或其他 TypeScript 模块的类型。在编译时TypeScript 编译器会在项目的根目录及其子目录中查找 .d.ts 文件。
  • declare module:用于声明一个模块的类型定义
    1. declare module “*.vue”: 声明一个模块,该模块匹配所有的 .vue 文件。
    2. import type {DefineComponent} from ‘vue’: 导入 DefineComponent 类型,这是 Vue.js 中的一个类型,用于表示 Vue 组件。
    3. const component: DefineComponent<{},{},any>: 定义一个名为 component 的常量,它的类型为 DefineComponent。这里的泛型参数分别代表:
      • 第一个参数 {} 表示组件的 props 类型为空。
      • 第二个参数 {} 表示组件的 emits 类型为空。
      • 第三个参数 any 表示组件的 data 类型为 any。

此时pnpm build打包时会报错:

ERROR in ./src/App.vue 1:0
Module parse failed: Unexpected token (1:0)
You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders
> <template>
| <div>
| test
@ ./src/main.ts 2:0-28 4:10-13

翻译:您可能需要一个适当的加载器来处理此文件类型,目前没有配置加载器来处理该文件。请参阅https://webpack.js.org/concepts#loaders

  • 打包工具webpack不认识<template>等代码,需要一个新的工具vue-loader

8 安装vue-loader

vue-loader官网

  • 安装vue-loader
pnpm add vue-loader -D
  • webpack.config.js中配置vue-loader
// 导入vue-loader
const { VueLoaderPlugin } = require("vue-loader");

const config = { // 执行命令npm run build,按照config中的配置打包文件
	...
    module: {
        rules: [
          // 以.vue结尾的文件,指定vue-loader加载器来处理
          {
            test: /\.vue$/,
            loader: 'vue-loader'
          },
        ]
      },
    plugins: [
		...
        // 引入vue-loader插件
        new VueLoaderPlugin(),
      ],
}
  • 作用vue Loader 是一个 webpackloader(加载器),它允许你以一种名为单文件组件 (SFCs)的格式撰写 Vue 组件

  • vue-loader部分工作流程:

    1. 调用@vue/compiler-sfc会解析文件,提取每个语言块,
    2. 通过标签中lang="ts"lang="scss"中lang的特性以及 webpack 配置中的规则自动推断出要使用的预处理(loader)
    3. vue-loader调用ts-loader预处理器,处理<script>部分;调用scss-loader预处理器,处理<style>部分
    4. 最后将他们组装成一个 ES Module,它的默认导出是一个 Vue.js 组件选项的对象。
  • Vue 单文件组件 (SFC) 规范:官网介绍
    vue 文件是一个自定义的文件类型,用类 HTML 语法描述一个 Vue 组件。每个 .vue 文件包含三种类型的顶级语言块 <template>、<script> 和 <style>,还允许添加可选的自定义块

  • vue-loader官网介绍说需要安装vue-template-compiler,在vue3中已经包含了相同功能的@vue/compiler-sfc插件,已经不需要再安装
    在这里插入图片描述

9 安装clean-webpack-plugin

  • 安装clean-webpack-plugin
pnpm add clean-webpack-plugin -D
  • 作用:用于在构建之前(pnpm build)清理输出目录(dist)。这个插件可以帮助你在每次构建时删除旧的构建文件,确保输出目录只包含最新构建的结果。这对于避免旧文件残留、减少混淆等问题非常有用。

  • webpack.config.js

// 导入clean-webpack-plugin
const { CleanWebpackPlugin } = require("clean-webpack-plugin");
    plugins: [
		...
        // 引入clean-webpack-plugin
        new CleanWebpackPlugin()
      ],
}

10. 结果

  • 在浏览器中正常执行
pnpm dev
  • 打包后,打开/dist/html文件,执行正常
 pnpm build

小结:

项目目录树

在这里插入图片描述

各文件代码

1. webpack.config.js
// 导入Configuration,使用注解的方式提供书写代码的智能提示
const {Configuration} = require("webpack");
// 导入vue-loader
const { VueLoaderPlugin } = require("vue-loader");
// 导入html-webpack-plugin
const HtmlWebpackPlugin = require("html-webpack-plugin");
// 导入clean-webpack-plugin
const { CleanWebpackPlugin } = require("clean-webpack-plugin");
const path = require("path");


/**
 * @type {Configuration}
 */
const config = { // 执行命令npm run build,按照config中的配置打包文件
    mode: 'development', // 开发模式
    entry: "./src/main.ts", // 入口文件
    module: {
        rules: [
          // 以.vue结尾的文件,指定使用vue-loader加载器来处理
          {
            test: /\.vue$/,
            loader: 'vue-loader'
          },
        ]
      },
    output: {
        filename: "[fullhash].js", // 输出文件名
        path: path.resolve(__dirname , "dist") // 输出路径
    },
    // resolve: {
    //     extensions: ['.tsx', '.ts', '.js'] // 自动解析扩展名
    // },
    plugins: [
        new HtmlWebpackPlugin({
          template: './public/index.html', // 指定模板文件
          filename: 'index.html',        // 输出文件名
          inject: 'body'                 // 注入的位置
        }),
        // 引入vue-loader插件
        new VueLoaderPlugin(),
        // 引入clean-webpack-plugin
        new CleanWebpackPlugin()
      ],
}

module.exports = config;
2. tsconfi.json
{
  "compilerOptions": {
  	  target: es2016  
	  module: commonjs 
	  strict: true 
	  esModuleInterop: true 
	  skipLibCheck: true 
	  forceConsistentCasingInFileNames: true 
  }
}
3. package.json
{
  "name": "webpack-demo",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "build": "webpack",
    "dev": "webpack-dev-server --open",
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "clean-webpack-plugin": "^4.0.0",
    "html-webpack-plugin": "^5.5.0",
    "ts-loader": "^9.5.1",
    "vue": "3.2.38",
    "vue-loader": "^17.4.2",
    "webpack": "^5.74.0",
    "webpack-cli": "^5.1.4",
    "webpack-dev-server": "^4.10.1"
  }
}

4. main.ts
import { createApp } from "vue";
import App from "./App.vue";

createApp(App).mount("#app");
5. end.d.ts
declare module "*.vue"{
    import type {DefineComponent} from 'vue'
    const component:DefineComponent<{},{},any>
    export default component
}
6. App.vue
<template>
  <div>
      test
  </div>
</template>

<script setup lang="ts"></script>

<style scoped ></style>

7. /public/index.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>webpack-demo</title>
</head>
<body>
    <div id="app"></div>
</body>
</html>

webpack.config.js中的其他配置项

    resolve: {
        alias: {
          '@': path.resolve(__dirname, 'src')
        },
        extensions: ['.tsx', '.ts', '.js'] // import 时,可以省略后缀名
    },

1. resolve解析器

官网详细说明

  • 设置模块如何被解析
  • 使用import和require时的相关配置

alias:设置别名

  • 设置@的别名
    resolve: {
        alias: {
          '@': path.resolve(__dirname, 'src')
        }
    },

  1. __dirname 是 Node.js 中的一个全局变量,用于表示当前文件所在的目录的绝对路径
  2. importrequire 语句中使用@时,相当于使用 当前文件的路径/src

extensions:省略后缀名

    resolve: {
        extensions: ['.tsx', '.ts', '.js'] // import 时,可以省略后缀名
    },
  1. 如需导入文件/src/views/index.js,可以不写后缀import ex from “src/views/index”
  2. 假如目录中有同名文件/src/views/index.ts,按照extensions给定的顺序导入的是ts文件

2. plugin 插件

作用: 各种方法修改webpack的构建过程,达到各种各样的目的

  1. 美化在构建过程中cmd中展示的各种信息
// 安装
pnpm add friendy-error-webpack-plugin -D
// 引入
const FriendlyErrorsWebpackPlugin = require("friendly-errors-webpack-plugin");
//使用
plugins: [
    // 引入friendly-errors-webpack-plugin
    new FriendlyErrorsWebpackPlugin({
      compilationSuccessInfo: {
        messages: [`You application is running here http://localhost:5173`],
      }
    }),
  ],

3. devServer 网络/服务相关配置

官网详细说明

  • 配置启动后监听的端口号,通过pnpm dev启动项目后,浏览器中端口号
  devServer: {
    port: 5173, // 端口号
  },

4. stats 控制台信息如何显示

官网的详细说明
作用: 控制台信息如何显示

  • 只有在错误时展示信息
stats:"errors-only",

5. module.rules配置预加载器

官方的详细说明

  • webpack原生只认识js和json文件,遇到其他类型文件时通过rules中配置规则,找对应的预加载器,把所有的文件都解析成js

  • rules中有多少loader,就需要pnpm安装多少loader

  module: {
    rules: [
      // 以.vue结尾的文件,指定使用vue-loader加载器来处理
      {
        test: /\.vue$/,
        use: "vue-loader",
      },
      // 以.css结尾的文件,指定使用css-loader和style-loader加载器来处理
      // use中的loader是倒序执行的,不能乱排顺序
      {
        test: /\.css$/,
        use: ["style-loader", "css-loader"],
      },
      // 以.ts结尾的文件,ts-loader加载器来处理
      // {
      //   test: /\.ts$/,
      //   use: [
      //     {
      //       loader: "ts-loader",
      //       options: {
      //         configFile: path.resolve(process.cwd(), "tsconfig.json"),
      //         appendTsSuffixTo: [/\.vue$/],
      //       },
      //     },
      //   ],
      // },
      {
        test: /\.ts$/,
        loader: "ts-loader",
        options: {
          configFile: path.resolve(process.cwd(), "tsconfig.json"),
          appendTsSuffixTo: [/\.vue$/],
        },
      },
    ],
  },

6. 外部扩展(Externals)

代码:

  externals: {
    vue: "Vue",
  },
  • 使用上述代码后,打包的文件中将不包含vue,在运行打包文件index.html会报错
    在这里插入图片描述
  • Vue给我们提供了CDN的引入方式:
<script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>

将上述代码插入到指定的模板文件index.html中再打包就可以运行了.

  • 优点:有效的减少打包后的体积,减少服务器的压力
  • 缺点:vue的相关文件都会从网络下载,会增加网络负担,如果网络传输速度不够快,直接影响使用者的体验

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

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

相关文章

什么是CSRF跨站请求伪造

CSRF&#xff08;跨站请求伪造&#xff0c;Cross-Site Request Forgery&#xff09;是一种网络攻击&#xff0c;攻击者通过伪造用户的身份&#xff0c;诱使用户在已认证的 Web 应用上执行非预期的操作。CSRF 攻击的风险在于它能够利用用户的身份认证状态&#xff0c;从而执行恶…

app逆向1-实战里常见东西

幕布链接&#xff1a;app逆向1-实战里常见东西 - 幕布

JVM性能监控实用工具jconsole与jvisualvm

jdk小工具jconsole与jvisualvm&#xff0c;jvisualvm为升级版的jconsole&#xff1b;通过命令行启动&#xff0c;可监控本地和远程应用。 推荐使用&#xff1a;jvisualvm jconsole使用 1.直接命令 jcondole 打开窗口&#xff0c;选择我们要查看的进行 连接后可看到面板 jvisu…

4岁患儿玩耍误伤眼内起迷“障”,耽误多年成都爱尔公益救助手术焕清晰

近日&#xff0c;成都爱尔眼科医院收治了一名来自西藏的7岁小患者小多。小多是由父亲带到医院的&#xff0c;可惜两人都不会汉语&#xff0c;医护人员与他们的交流依靠着孩子父亲拨打的亲戚电话&#xff0c;在电话中一句一句的翻译终于厘清病情原委。 据说&#xff0c;3年前小多…

固态硬盘损坏,有什么方法可以恢复数据?

我认为值得推荐的固态硬盘数据恢复&#xff0c;必须满足2个硬条件&#xff1a; 恢复成功率高 不损害原文件&#xff0c;保证数据的绝对安全 推荐2个超好用的U盘数据恢复神器&#xff0c;帮你快速找回重要文件&#xff01; 1、转转数据恢复大师 点击直达链接>>www.huifuz…

简单工作流-节点增加输入内容

之前已经做完了前端的流程图像绘制&#xff0c;后端对流程图像的CURD&#xff0c;现在主要做流程节点的必要属性做完善&#xff0c;之前只做了节点上权限用户的绑定没有对用户输入内容做管理&#xff0c;现在加上了输入内容管理&#xff0c;具体代码在github上&#xff1a; 前端…

css-50 Projects in 50 Days(1)

改变背景图 html <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>改变背景</title><link …

【ceph学习】rgw网关进程如何启动

rgw 网关进程启动 主要在rgw_main.cc的main函数中&#xff0c;主要涉及一些关键线程启动、前端服务器&#xff08;beast等&#xff09;启动、后端存储模块启动&#xff08;rados&#xff09;、perf和log启动等。 流程图关键节点如下&#xff1a; 1、beast的启动 2、rados的启…

对标GPT4o,智谱推出新一代基座大模型 GLM-4-Plus

最新基座大模型 GLM-4-Plus发布并上线开放平台 在 KDD 国际数据挖掘与知识发现大会上&#xff0c;智谱 GLM 团队介绍了新一代基座大模型GLM-4-Plus。GLM-4-Plus 是智谱全自研 GLM 大模型的最新版本&#xff0c;它标志着智谱继续瞄准通用人工智能&#xff0c;持续推进大模型技术…

Django框架安全

【图书介绍】《Django 5企业级Web应用开发实战&#xff08;视频教学版&#xff09;》_django 5企业级web应用开发实战(视频教学版)-CSDN博客 《Django 5企业级Web应用开发实战&#xff08;视频教学版&#xff09;》(王金柱)【摘要 书评 试读】- 京东图书 (jd.com) 本节主要介…

阿里PAI-ChatLearn:大规模 Alignment高效训练框架正式开源

导读 ChatGPT是OpenAI开发的基于大型语言模型(LLM)的聊天机器人&#xff0c;以其令人惊叹的对话能力而迅速火爆并被广泛采用。ChatGPT 成功背后得益于大型语言模型生成领域的新训练范式&#xff1a;RLHF (Reinforcement Learning from Human Feedback)&#xff0c;即以强化学习…

代码随想录第十天——LeetCode 150. 逆波兰表达式求值、239. 滑动窗口最大值、347.前 K 个高频元素

150. 逆波兰表达式求值 力扣题目链接(opens new window) 根据 逆波兰表示法&#xff0c;求表达式的值。 有效的运算符包括 , - , * , / 。每个运算对象可以是整数&#xff0c;也可以是另一个逆波兰表达式。 说明&#xff1a; 整数除法只保留整数部分。 给定逆波兰表达式总是…

weditor使用问题总结

1.Pixel连接weditor提示Local server not started 产生原因1&#xff1a;开发者模式关闭后重开部分选项没勾选 解决方案&#xff1a;打开如下设置即可 产生原因2&#xff1a;安装了uiautodev导致uiautomator2版本升级到了3.x版本 解决方案&#xff1a;重新安装uiautomator2的…

Nginx: 缓存, 不缓存特定内容和缓存失效降低上游压力策略及其配置示例

概述 在负载均衡的过程中&#xff0c;有一个比较重要的概念&#xff0c;就是缓存利用缓存可以很好协调Nginx在客户端和上游服务器之间的速度不匹配的矛盾从而很好的解决整体系统的响应速度 如果用户需要通过Nginx获取某一些内容的时候&#xff0c;发起一个request请求这个请求…

我在高职教STM32——ADC电压采集与光敏电阻(4)

大家好,我是老耿,高职青椒一枚,一直从事单片机、嵌入式、物联网等课程的教学。对于高职的学生层次,同行应该都懂的,老师在课堂上教学几乎是没什么成就感的。正是如此,才有了借助 CSDN 平台寻求认同感和成就感的想法。在这里,我准备陆续把自己花了很多心思设计的教学课件…

linux每个memory cgroup的lru链表是什么创建的

1.概述 对Linux memory子系统有基本了解的都知道&#xff0c;linux内核通过LRU管理物理内存&#xff0c;不知道是否有思考过如下问题&#xff1a;LRU是全局一套&#xff0c;还是说每个memory cgroup拥有单独的一套LRU链表&#xff1f;直接揭晓答案&#xff1a;每个memory cgro…

Typora + PicGo + Gitee 实现图片自动上传

Typora PicGo Gitee 实现图片自动上传 1.配置Gitee1.创建Gitee仓库2.设置私人令牌2. PicGo 的安装配置2.1 下载 PicGo2.2 安装 PicGo2.3 安装 PicGo 的自动上传插件2.4 Gitee 图床设置 3. Typora 安装配置3.1 安装**版本3.2 配置 PicGo 4. 上传验证 1.配置Gitee 1.创建Gitee…

字节AI辅助编程工具MarsCode,开启高效编程之旅

点击链接即可注册和使用&#xff1a;豆包MarsCode 一、巨头较量&#xff0c;MarsCode 崭露头角 在当今的编程世界中&#xff0c;代码补全工具层出不穷。阿里的通义灵码凭借阿里强大的技术实力&#xff0c;在代码补全方面表现出色&#xff0c;能够快速理解程序员的意图&#x…

tomcat在eclipse中起动成功,无法访问tomcat主页

最近通过geoserver的war包将&#xff0c;geoserver服务部署到了tomcat&#xff0c;发现在eclipse中启动服务后&#xff0c;无法访问localhost&#xff1a;8080主页&#xff0c;geoserver主页&#xff1a;localhost:8080/geoserver/web同样也无法访问。 只需要双击下面的server…

css画个熊猫

【html源码-一键复制查看效果】 <!DOCTYPE html> <html><head><meta charset"utf-8" /><title></title><style>* {margin: 0;padding: 0;box-sizing: border-box;}.box {position: relative;width: 300px;height: 260px;…