How to load SVG in Webpack
This article mainly introduces the actual method of loading SVG with Webpack. Now I will share it with you and give you a reference.
As a standard format for vector graphics, SVG has been supported by major browsers, and it has also become synonymous with vector graphics on the Web. Using SVG instead of bitmaps in web pages has the following benefits:
SVG is clearer than bitmaps and will not destroy the clarity of graphics under arbitrary scaling. SVG can facilitate It effectively solves the problem of unclear image display on high-resolution screens.
When the graphic lines are relatively simple, the size of the SVG file is smaller than the bitmap. Today, when flat UI is popular, SVG will be smaller in most cases.
SVG with the same graphics has better rendering performance than the corresponding high-definition graphics.
SVG uses XML syntax description consistent with HTML, and is highly flexible.
The drawing tool can export .svg files individually. The import method of SVG is similar to that of images. It can be used directly in CSS as follows:
1 2 3 |
|
Also Used in HTML:
1 |
|
That is to say, the SVG file can be used directly as a picture, and the method is exactly the same as when using pictures. Therefore, the two methods introduced in 3-19 Loading Images using file-loader and using url-loader are equally effective for SVG. You only need to change the file suffix in the Loader test configuration to .svg. The code is as follows:
1 2 3 4 5 6 7 8 9 10 |
|
Since SVG is a text format file, there are other methods besides the above two methods, which will be explained one by one below.
Use raw-loader
raw-loader can read the contents of the text file and inject it into JavaScript or CSS.
For example, write this in JavaScript:
1 |
|
The output code after raw-loader processing is as follows:
1 |
|
That is to say, the content of svgContent is equal to the string form SVG, since SVG itself is an HTML element, after obtaining the SVG content, you can directly insert the SVG into the web page through the following code:
1 |
|
The relevant Webpack configuration when using raw-loader is as follows:
1 2 3 4 5 6 7 8 9 10 |
|
Since raw-loader will directly return the text content of SVG and cannot display the text content of SVG through CSS, SVG cannot be imported into CSS after using this method. That is to say, code such as background-image: url(./svgs/activity.svg) cannot appear in CSS, because background-image: url() is illegal of.
This example provides the complete code of the project
Using svg-inline-loader
svg-inline-loader and the raw-loader mentioned above are very Similar, but the difference is that svg-inline-loader will analyze the content of SVG and remove unnecessary code to reduce the file size of SVG.
After using drawing tools such as Adobe Illustrator and Sketch to create SVG, these tools will generate unnecessary code for the web page to run when exporting. For example, the following is the SVG code exported by Sketch:
1 2 3 4 |
|
After being processed by svg-inline-loader, it will be streamlined into the following:
1 |
|
In other words, svg-inline-loader has been added Compression function for SVG.
The relevant Webpack configuration when using svg-inline-loader is as follows:
1 2 3 4 5 6 7 8 9 10 |
|
This example provides the complete code of the project
The above is what I compiled for everyone, I hope it will be useful to you in the future Everyone is helpful.
Related articles:
How to integrate vux in vue.js to implement pull-up loading and pull-down refresh
Related vue projects in webpack Resource file reports 404 problem (detailed tutorial)
Use webpack vue2 for project construction
About how to implement secondary linkage in vue, the default selection is A value
Using ui-route to implement multi-layer nested routing in AngularJS (detailed tutorial)
The above is the detailed content of How to load SVG in Webpack. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics











Vue is an excellent JavaScript framework that can help us quickly build interactive and efficient web applications. Vue3 is the latest version of Vue, which introduces many new features and functionality. Webpack is currently one of the most popular JavaScript module packagers and build tools, which can help us manage various resources in our projects. This article will introduce how to use Webpack to package and build Vue3 applications. 1. Install Webpack

Differences: 1. The startup speed of the webpack server is slower than that of Vite; because Vite does not require packaging when starting, there is no need to analyze module dependencies and compile, so the startup speed is very fast. 2. Vite hot update is faster than webpack; in terms of HRM of Vite, when the content of a certain module changes, just let the browser re-request the module. 3. Vite uses esbuild to pre-build dependencies, while webpack is based on node. 4. The ecology of Vite is not as good as webpack, and the loaders and plug-ins are not rich enough.

With the continuous development of web development technology, front-end and back-end separation and modular development have become a widespread trend. PHP is a commonly used back-end language. When doing modular development, we need to use some tools to manage and package modules. Webpack is a very easy-to-use modular packaging tool. This article will introduce how to use PHP and webpack for modular development. 1. What is modular development? Modular development refers to decomposing a program into different independent modules. Each module has its own function.

Configuration method: 1. Use the import method to put the ES6 code into the packaged js code file; 2. Use the npm tool to install the babel-loader tool, the syntax is "npm install -D babel-loader @babel/core @babel/preset- env"; 3. Create the configuration file ".babelrc" of the babel tool and set the transcoding rules; 4. Configure the packaging rules in the webpack.config.js file.

As the complexity of modern web applications continues to increase, building excellent front-end engineering and plug-in systems has become increasingly important. With the popularity of Spring Boot and Webpack, they have become a perfect combination for building front-end projects and plug-in systems. SpringBoot is a Java framework that creates Java applications with minimal configuration requirements. It provides many useful features, such as automatic configuration, so that developers can build and deploy web applications faster and easier. W

In vue, webpack can package js, css, pictures, json and other files into appropriate formats for browser use; in webpack, js, css, pictures, json and other file types can be used as modules. Various module resources in webpack can be packaged and merged into one or more packages, and during the packaging process, the resources can be processed, such as compressing images, converting scss to css, converting ES6 syntax to ES5, etc., which can be recognized by HTML. file type.

Webpack is a module packaging tool. It creates modules for different dependencies and packages them all into manageable output files. This is especially useful for single-page applications (the de facto standard for web applications today).

How does Webpack implement packaging? The following article will give you an in-depth understanding of Webpack packaging principles. I hope it will be helpful to you!
