Why is ES6 code not translated to ES5 when Vite builds JS library?
Vite builds JS library: Solution for ES6 code not translated to ES5
When using Vite to build JS libraries, developers often encounter problems that ES6 code is not translated to ES5, which leads to compatibility errors in the old browser environment. This article analyzes a case and provides solutions.
In the case, the developer used Vite to build the JS library and used ES6's null value merge operator (??), but the packaged code still contains ES6 syntax, resulting in an error. Its vite.config.js
configuration is as follows:
import { defineConfig } from "vite"; import babel from "@rollup/plugin-babel"; export default defineConfig({ build: { lib: { entry: "./lib/main.js", name: "FastcodeTest", fileName: (format) => `fastcodeTest.${format}.js`, formats: ["es", "umd"], }, }, rollupOptions: { plugins: [ babel({ babelHelpers: "bundled", exclude: "node_modules/**", presets: [ [ "@babel/preset-env", { targets: { browsers: "> 0.25%, not dead", // Set the target browser}, useBuiltIns: "entry", corejs: 3, }, ], ], }), ], }, });
The root cause of the problem lies in targets: { browsers: "> 0.25%, not dead" }
. This configuration sets the target browser to a browser with a share of more than 0.25% and no maintenance has been stopped. Modern browsers natively support ES6, so Babel will not translate.
Solution:
To ensure ES5 compatibility, you need to modify targets
configuration to explicitly specify lower version browsers, for example:
targets: { browsers: ["ie >= 11", "last 2 versions", "not dead"] // or more specific version number}
Alternatively, for more granular control, consider using a more comprehensive browser compatibility list, such as the configuration provided by browserslist
. In addition, other reasons that may cause errors, such as node environment version differences, need to be ruled out. Only after other factors are excluded, the Babel configuration will be adjusted. Make sure the @babel/preset-env
plugin is installed correctly.
By modifying targets
configuration, Babel will correctly translate the ES6 code to ES5, thus solving the compatibility issue. Remember, choosing the right targets
configuration depends on the support range of your target browser.
The above is the detailed content of Why is ES6 code not translated to ES5 when Vite builds JS library?. 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

AI Hentai Generator
Generate AI Hentai for free.

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



Configuring a Debian mail server's firewall is an important step in ensuring server security. The following are several commonly used firewall configuration methods, including the use of iptables and firewalld. Use iptables to configure firewall to install iptables (if not already installed): sudoapt-getupdatesudoapt-getinstalliptablesView current iptables rules: sudoiptables-L configuration

The steps to install an SSL certificate on the Debian mail server are as follows: 1. Install the OpenSSL toolkit First, make sure that the OpenSSL toolkit is already installed on your system. If not installed, you can use the following command to install: sudoapt-getupdatesudoapt-getinstallopenssl2. Generate private key and certificate request Next, use OpenSSL to generate a 2048-bit RSA private key and a certificate request (CSR): openss

Using OpenSSL for digital signature verification on Debian systems, you can follow these steps: Preparation to install OpenSSL: Make sure your Debian system has OpenSSL installed. If not installed, you can use the following command to install it: sudoaptupdatesudoaptininstallopenssl to obtain the public key: digital signature verification requires the signer's public key. Typically, the public key will be provided in the form of a file, such as public_key.pe

In Debian systems, OpenSSL is an important library for encryption, decryption and certificate management. To prevent a man-in-the-middle attack (MITM), the following measures can be taken: Use HTTPS: Ensure that all network requests use the HTTPS protocol instead of HTTP. HTTPS uses TLS (Transport Layer Security Protocol) to encrypt communication data to ensure that the data is not stolen or tampered during transmission. Verify server certificate: Manually verify the server certificate on the client to ensure it is trustworthy. The server can be manually verified through the delegate method of URLSession

Managing Hadoop logs on Debian, you can follow the following steps and best practices: Log Aggregation Enable log aggregation: Set yarn.log-aggregation-enable to true in the yarn-site.xml file to enable log aggregation. Configure log retention policy: Set yarn.log-aggregation.retain-seconds to define the retention time of the log, such as 172800 seconds (2 days). Specify log storage path: via yarn.n

Apache server is a powerful web server software that acts as a bridge between browsers and website servers. 1. It handles HTTP requests and returns web page content based on requests; 2. Modular design allows extended functions, such as support for SSL encryption and dynamic web pages; 3. Configuration files (such as virtual host configurations) need to be carefully set to avoid security vulnerabilities, and optimize performance parameters, such as thread count and timeout time, in order to build high-performance and secure web applications.

Configuring an HTTPS server on a Debian system involves several steps, including installing the necessary software, generating an SSL certificate, and configuring a web server (such as Apache or Nginx) to use an SSL certificate. Here is a basic guide, assuming you are using an ApacheWeb server. 1. Install the necessary software First, make sure your system is up to date and install Apache and OpenSSL: sudoaptupdatesudoaptupgradesudoaptinsta

The CentOS shutdown command is shutdown, and the syntax is shutdown [Options] Time [Information]. Options include: -h Stop the system immediately; -P Turn off the power after shutdown; -r restart; -t Waiting time. Times can be specified as immediate (now), minutes ( minutes), or a specific time (hh:mm). Added information can be displayed in system messages.
