详解vue-cli之webpack3构建全面提速优化

yizhihongxing

标题

详解vue-cli之webpack3构建全面提速优化

简介

Vue-cli是Vue框架官方提供的脚手架工具,能够帮助我们快速搭建项目,减少开发成本。而webpack则是目前比较流行的打包工具。本攻略将介绍如何在Vue-cli中使用webpack3构建项目,并进行全面提速优化。

步骤

1. 安装vue-cli

首先,我们需要安装Vue-cli。在命令行中输入以下命令:

npm install -g vue-cli

2. 创建Vue项目

创建Vue项目很简单。在命令行中输入以下命令:

vue init webpack myproject

其中,myproject是项目名称,可以根据自己的需要进行修改。

3. 运行项目

创建好项目后,我们就可以运行项目了。在命令行中进入到项目目录下,输入以下命令:

npm run dev

然后在浏览器中打开 http://localhost:8080/ ,就可以看到项目的运行效果了。

4. 优化webpack配置文件

Vue-cli默认生成的webpack配置文件,性能并不是特别好。因此,我们需要进行一些优化。

4.1 使用CDN加速静态资源

使用CDN加速静态资源可以大大减轻服务器的负担,这对于大型项目来说尤为重要。

我们可以修改webpack.base.conf.js文件,将官方提供的CDN path替换成自己的CDN:

output: {
  path: config.build.assetsRoot,
  filename: utils.assetsPath('js/[name].[chunkhash].js'),
  chunkFilename: utils.assetsPath('js/[id].[chunkhash].js'),
  publicPath: 'https://cdn.example.com/' // 替换成你自己的CDN
},

4.2 使用DllPlugin插件

使用DllPlugin插件可以将第三方模块单独打包,减少构建时间。我们可以创建一个webpack.dll.conf.js文件,进行单独打包。

具体操作可以参考以下代码:

const path = require('path')
const webpack = require('webpack')

module.exports = {
  mode: 'production',
  entry: {
    vendor: [
      'vue',
      'vue-router',
      'lodash',
      'moment',
      'axios'
    ]
  },
  output: {
    path: path.join(__dirname, '../static/dll'),
    filename: '[name].dll.js',
    library: '[name]_library'
  },
  plugins: [
    new webpack.DllPlugin({
      path: path.join(__dirname, '../static/dll', '[name]-manifest.json'),
      name: '[name]_library'
    })
  ]
}

5. 结束语

使用以上方法,可以对Vue-cli项目进行全面的提速优化。当然,这还只是一个开始,我们可以根据项目需要,对webpack配置进行更加细致的优化。

示范代码

在第4节中,我们提到了如何进行webpack配置文件的优化。这里提供一个完整的webpack.base.conf.js的示范代码,供参考:

const path = require('path')
const utils = require('./utils')
const config = require('../config')
const vueLoaderConfig = require('./vue-loader.conf')

function resolve (dir) {
  return path.join(__dirname, '..', dir)
}

module.exports = {
  context: path.resolve(__dirname, '../'),
  entry: {
    app: './src/main.js'
  },
  output: {
    path: config.build.assetsRoot,
    filename: '[name].js',
    publicPath: process.env.NODE_ENV === 'production'
      ? config.build.assetsPublicPath
      : config.dev.assetsPublicPath
  },
  resolve: {
    extensions: ['.js', '.vue', '.json'],
    alias: {
      'vue$': 'vue/dist/vue.esm.js',
      '@': resolve('src')
    }
  },
  module: {
    rules: [
      {
        test: /\.(js|vue)$/,
        loader: 'eslint-loader',
        enforce: 'pre',
        include: [resolve('src'), resolve('test')],
        options: {
          formatter: require('eslint-friendly-formatter')
        }
      },
      {
        test: /\.vue$/,
        loader: 'vue-loader',
        options: vueLoaderConfig
      },
      {
        test: /\.js$/,
        loader: 'babel-loader',
        include: [resolve('src'), resolve('test')]
      },
      {
        test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
        loader: 'url-loader',
        options: {
          limit: 10000,
          name: utils.assetsPath('img/[name].[hash:7].[ext]')
        }
      },
      {
        test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/,
        loader: 'url-loader',
        options: {
          limit: 10000,
          name: utils.assetsPath('media/[name].[hash:7].[ext]')
        }
      },
      {
        test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
        loader: 'url-loader',
        options: {
          limit: 10000,
          name: utils.assetsPath('fonts/[name].[hash:7].[ext]')
        }
      }
    ]
  },
  node: {
    // prevent webpack from injecting useless setImmediate polyfill because Vue
    // source contains it (although only uses it if it's native).
    setImmediate: false,
    // prevent webpack from injecting mocks to Node native modules
    // that does not make sense for the client
    dgram: 'empty',
    fs: 'empty',
    net: 'empty',
    tls: 'empty',
    child_process: 'empty'
  }
}

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:详解vue-cli之webpack3构建全面提速优化 - Python技术站

(0)
上一篇 2023年5月28日
下一篇 2023年5月28日

相关文章

  • VUE+Canvas 实现桌面弹球消砖块小游戏的示例代码

    首先,使用Vue.js和Canvas API实现桌面弹球消砖块小游戏需要完成以下步骤: 创建基本的Vue.js应用程序结构,包括模板、组件和数据绑定。 在Vue.js组件中创建一个Canvas元素,并使用Canvas API绘制游戏元素。 使用Vue.js监听用户交互事件,并更新Canvas元素以实现用户操作。 实现游戏逻辑,包括弹球的运动轨迹、碰撞检测和砖…

    Vue 2023年5月27日
    00
  • Vue的混合继承详解

    Vue的混合继承详解 在Vue中,混合继承(Mixins)是一种非常常用的组件复用方式。它允许我们将多个组件共用的代码提取到一个混合对象中,然后在需要的组件中使用mixins选项进行混合。 一、基本用法 我们将要使用到一个示例,这是一个Vue组件定义的基本结构: Vue.component(‘my-component’, { mixins: [myMixin…

    Vue 2023年5月28日
    00
  • vue使用自定义事件的表单输入组件用法详解【日期组件与货币组件】

    Vue使用自定义事件的表单输入组件用法详解【日期组件与货币组件】 简介 Vue是一种用于构建用户界面的渐进式框架,支持单文件组件,可以非常方便地组合和使用组件来构建应用。自定义表单输入组件可以让开发者轻松地实现与表单的交互,并支持一些常用特性。本篇文档主要介绍如何使用自定义事件来实现日期组件和货币组件,帮助开发者更好地理解自定义表单输入组件的使用方法。 准备…

    Vue 2023年5月28日
    00
  • vue+axios+promise实际开发用法详解

    vue+axios+promise实际开发用法详解 什么是axios和promise axios axios是一个基于Promise用于浏览器和node.js的HTTP客户端。它具有以下特征: 支持浏览器和 node.js 支持 Promise API 拦截请求和响应 转换请求和响应数据 Promise Promise是一种用于异步编程的语言特性,它可以让我…

    Vue 2023年5月28日
    00
  • vue中导出Excel表格的实现代码

    下面是详细讲解如何在Vue中实现导出Excel表格的步骤。 1. 安装相关插件 要在Vue中导出Excel表格,需要安装以下插件: xlsx: 用于构建Excel文件。 file-saver: 用于提供文件下载功能。 在项目的根目录下使用npm进行安装: npm install xlsx file-saver –save 2. 编写导出方法 在Vue的组件…

    Vue 2023年5月27日
    00
  • vue实现简易的计算器功能

    Vue.js 实现简易计算器 在这个例子中,我们将使用Vue.js来构建一个简单的计算器应用。 步骤1:创建Vue实例 首先,我们需要引入Vue.js库。我们可以直接将vue.js文件引入到HTML页面中。 <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js">&…

    Vue 2023年5月27日
    00
  • Vue.js实战之组件之间的数据传递

    Vue.js是一个流行的JavaScript框架,其中组件是Vue.js中最重要的概念之一。在组件化开发中,组件是可重用的代码块,它们通常具有自己的状态和行为,并且可以相互交互。在本文中,我们将探讨Vue.js中组件之间的数据传递。 父组件向子组件传递数据 在Vue.js中,父组件可以通过props向子组件传递数据。props是子组件接收的属性,可以像下面这…

    Vue 2023年5月28日
    00
  • vue基础语法之插值表达式详解

    Vue基础语法之插值表达式详解 什么是插值表达式? 在Vue中,我们可以使用插值表达式将数据绑定到模板上,从而动态地渲染出页面的内容。插值表达式是一种括在双大括号中的JavaScript表达式,Vue会将其解释并渲染出对应的结果。 插值表达式的语法 Vue的插值表达式语法非常简单,只需要在模板中使用双大括号包裹JavaScript表达式即可。 <!–…

    Vue 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部