docs_vue2/one/docs/en-US/getting-started/index.md

2.4 KiB

Getting started

:::tip To make VEUI works in your project, please install and configure according to all of the following steps. :::

Installation

After scaffolding the project with Vue CLI, run the following under the its root directory:

npm i --save veui veui-theme-dls
npm i --save-dev less less-loader veui-loader babel-plugin-veui babel-plugin-lodash

Configuration

Babel plugin

You need to configure the auto-generated babel.config.js as follows:

module.exports = {
  presets: [
    '@vue/app'
  ],
  plugins: [
    'veui',
    'lodash'
  ]
}

Read more about babel-plugin-veui here.

webpack Loader

In general, you need to configure vue.config.js in the root directory as follows:

module.exports = {
  css: {
    loaderOptions: {
      less: {
        javascriptEnabled: true
      }
    }
  },
  transpileDependencies: [
    'veui',
    'vue-awesome',
    'resize-detector'
  ],
  chainWebpack: config => {
    config.module
      .rule('veui')
      .test(/\.vue$/)
      .pre()
      .use('veui-loader')
      .loader('veui-loader')
      .tap(() => {
        return {
          modules: [
            {
              package: 'veui-theme-dls',
              fileName: '{module}.less'
            },
            {
              package: 'veui-theme-dls',
              fileName: '{module}.js',
              transform: false
            }
          ]
        }
      })
  }
}

To learn more details of configuring veui-loader, read its documentation here.

+++Why all these configs? VEUI's style code is separate from its components. The component code doesn't explicitly depend on style code so veui-loader is needed to specify and inject style package into the components.

If you want to use veui-theme-dls, the default style package, you need import and configure veui-loader for webpack. As Less 3+ no longer enable JavaScript evaluation by default, which veui-theme-dls relies on, you need to manually enable this option.

We intend to transpile and build VEUI and its dependencies along with the application code itself so you need to add the related packages into the transpilation process. +++

Global stylesheet

When using veui-theme-dls, you need to import the base stylesheet, which includes style normalization.

Import from JavaScript:

import 'veui-theme-dls/common.less'
import 'focus-visible'