当前位置: 首页 > news >正文

用自己的服务器做网站怎么制作个人网站

用自己的服务器做网站,怎么制作个人网站,邹城网站建设zczwxx,游戏网站建设的策划Webpack Bundle Analyzer是一个用于可视化的工具,它可以帮助你分析Webpack打包后的输出文件,查看哪些模块占用了最多的空间,从而进行优化。 2500G计算机入门到高级架构师开发资料超级大礼包免费送! 首先,你需要安装W…

Webpack Bundle Analyzer是一个用于可视化的工具,它可以帮助你分析Webpack打包后的输出文件,查看哪些模块占用了最多的空间,从而进行优化。

2500G计算机入门到高级架构师开发资料超级大礼包免费送!

首先,你需要安装Webpack Bundle Analyzer和Webpack本身:

npm install webpack webpack-cli --save-dev
npm install webpack-bundle-analyzer --save-dev

接下来,配置Webpack配置文件(webpack.config.js):

const path = require('path');
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;module.exports = {entry: './src/index.js',output: {filename: 'bundle.js',path: path.resolve(__dirname, 'dist'),},plugins: [new BundleAnalyzerPlugin({analyzerMode: 'static',reportFilename: 'report.html',openAnalyzer: false, // 不自动打开浏览器}),],// 其他配置...
};

运行Webpack并生成分析报告:

npx webpack --mode production

这将在dist目录下生成一个report.html文件,打开这个文件,你将看到一个交互式的图表,显示了你的包的大小分布。

为了进一步优化,你可以采取以下策略:

代码分割(Code Splitting):

使用splitChunks配置项将大型库或组件拆分为单独的chunk,只在需要时加载。

module.exports = {// ...optimization: {splitChunks: {chunks: 'all',},},// ...
};
Tree Shaking:

启用sideEffects属性和ES模块,让Webpack删除未使用的代码。

// package.json
{"sideEffects": false
}
javascript
// 在Webpack配置中启用ES模块
module.exports = {// ...module: {rules: [{test: /\.m?js$/,resolve: {fullySpecified: false,},},],},// ...
};

使用压缩插件:

使用TerserWebpackPlugin或其他压缩工具减小文件大小。

const TerserWebpackPlugin = require('terser-webpack-plugin');module.exports = {// ...optimization: {minimize: true,minimizer: [new TerserWebpackPlugin(),],},// ...
};

加载器优化:

根据需要选择合适的加载器,例如使用url-loaderfile-loader处理静态资源,设置合适的阈值以避免不必要的转换。

module.exports = {// ...module: {rules: [{test: /\.(png|jpg|gif)$/i,use: [{loader: 'url-loader',options: {limit: 8192, // 8KBfallback: 'file-loader',},},],},],},// ...
};

模块懒加载(Lazy Loading)

对于大型应用,可以使用动态导入(import())实现模块懒加载,只有在用户需要时才加载相关模块。

// Before
import SomeBigComponent from './SomeBigComponent';// After
const SomeBigComponent = () => import('./SomeBigComponent');

代码预热(Code Preheating)

对于频繁使用的懒加载模块,可以考虑预热,提前加载,减少首次使用时的延迟。

// 在应用启动时预加载组件
import('./SomeBigComponent').then(() => {console.log('SomeBigComponent preloaded');
});

提取公共库(Common Chunks)

通过optimization.splitChunks配置,可以将多个模块共享的库提取到单独的chunk中。

module.exports = {// ...optimization: {splitChunks: {cacheGroups: {vendors: {test: /[\\/]node_modules[\\/]/,priority: -10,chunks: 'initial',},common: {name: 'common',test: /[\\/]src[\\/]/,chunks: 'all',minChunks: 2,priority: -20,reuseExistingChunk: true,},},},},// ...
};

使用CDN引入库

对于第三方库,如果它们在所有页面中都使用,考虑从CDN引入,减少服务器负载和首次加载时间。

// 在HTML模板中
<script src="https://cdn.example.com/jquery.min.js"></script>

图片优化

使用image-webpack-loadersharp库对图片进行压缩和优化。

module.exports = {// ...module: {rules: [{test: /\.(png|jpe?g|gif|svg)$/i,use: [{loader: 'image-webpack-loader',options: {bypassOnDebug: true, // webpack@4 compatibilitymozjpeg: {progressive: true,quality: 65,},optipng: {enabled: false,},pngquant: {quality: [0.65, 0.9],speed: 4,},gifsicle: {interlaced: false,},// the webp option will enable WEBPwebp: {quality: 75,},},},],},],},// ...
};

利用缓存

使用cache配置来缓存Webpack编译结果,加快后续构建速度。

module.exports = {// ...cache: {type: 'filesystem',},// ...
};

避免重复的模块

使用Module Federationexternals配置,避免在多个应用之间重复引入相同的库。

Module Federation (Webpack 5+)

// 主应用 (Host App)
module.exports = {// ...experiments: {outputModule: true,},externals: {react: 'React','react-dom': 'ReactDOM',},// ...plugins: [new ModuleFederationPlugin({name: 'host_app',remotes: {remote_app: 'remote_app@http://localhost:3001/remoteEntry.js',},shared: ['react', 'react-dom'],}),],// ...
};// 远程应用 (Remote App)
module.exports = {// ...experiments: {outputModule: true,},plugins: [new ModuleFederationPlugin({name: 'remote_app',filename: 'remoteEntry.js',exposes: {'./RemoteComponent': './src/RemoteComponent',},}),],// ...
};

externals配置

module.exports = {// ...externals: {react: 'React','react-dom': 'ReactDOM',},// ...
};

这将告诉Webpack这些库已经在全局作用域中可用,避免重复打包。

使用Source Maps

在开发阶段启用Source Maps,便于调试。

module.exports = {// ...devtool: 'cheap-module-source-map',// ...
};

优化字体和图标

对于图标和字体,可以使用url-loaderfile-loader配合limit参数来决定是否内联到CSS或单独打包。

module.exports = {// ...module: {rules: [{test: /\.(woff|woff2|eot|ttf|otf|svg)$/,use: [{loader: 'url-loader',options: {limit: 10000,name: '[name].[ext]',outputPath: 'fonts/',},},],},],},// ...
};

避免全局样式污染

使用CSS Modules或Scoped CSS,限制CSS作用域,防止样式冲突。

// CSS Modules
import styles from './styles.module.css';// Scoped CSS
<style scoped>.myClass { /* ... */ }
</style>

优化HTML输出

使用HtmlWebpackPlugin生成优化过的HTML模板,自动引入Webpack生成的脚本和样式。

const HtmlWebpackPlugin = require('html-webpack-plugin');module.exports = {// ...plugins: [new HtmlWebpackPlugin({template: './public/index.html',inject: 'body', // 将脚本注入到body底部}),],// ...
};

使用Webpack Dev Server

在开发环境中使用Webpack Dev Server,实现热更新和快速迭代。

module.exports = {// ...devServer: {contentBase: './dist',hot: true,},// ...
};

2500G计算机入门到高级架构师开发资料超级大礼包免费送!

http://www.qdjiajiao.com/news/7502.html

相关文章:

  • 世界知名网站seo点击排名软件哪家好
  • 怎么网站制作商铺营销推广方案
  • 响应式网站和网站seo重庆
  • 安徽建设厅网站地址厦门人才网唯一官方网站
  • 用自己的手机做网站百度一下就会知道了
  • 可以做装修效果图的网站有哪些友情链接有哪些
  • 网站制作设计教程凌哥seo技术博客
  • 网上赚钱靠谱吗seo搜索引擎优化服务
  • 包装设计效果图电商关键词排名优化怎么做?
  • 网站开发南城科技大厦微信管理
  • 小程序网站开发公司网络营销企业网站推广
  • wordpress 小说插件seo是什么seo怎么做
  • 建设自己的企业网站需要什么资料seo公司上海牛巨微
  • 塑料袋销售做哪个网站推广好软文推广公司有哪些
  • 保定网页制作谷歌seo优化怎么做
  • 怎么做虚拟的网站搜索引擎seo排名优化
  • 怎样让客户做网站搜狗网站排名软件
  • 免费静态网站模板下载实体店引流推广方法
  • 南京网络设计汕头seo推广外包
  • 浏览器一打开就是2345网址导航网络优化工程师有前途吗
  • 产品网站设计武汉百度推广seo
  • 网络销售怎么做网站提高关键词排名的软文案例
  • 监控摄像头做直播网站网络营销官网
  • h5响应式网站源码营销型网站建设多少钱
  • 网站制作杭州百度账号人工申诉
  • 中文小说网站建设与维护游戏网站交换友情链接
  • 用自己照片做衣服_杯子的是哪个网站营销技巧培训
  • 做卷子的网站郑州学校网站建设
  • 太原做网站软件google seo教程
  • python一句做网站直通车怎么开效果最佳