ホームページ  >  記事  >  ウェブフロントエンド  >  Vue フロントエンド アーキテクチャの学習 (1)

Vue フロントエンド アーキテクチャの学習 (1)

小云云
小云云オリジナル
2018-02-02 13:53:512257ブラウズ

この記事では、Vue フロントエンド アーキテクチャの学習 (1) を主に共有します。これは、皆様のお役に立てれば幸いです。

考えてみれば、私はすでに多くのアーキテクチャ プロジェクトを行っており、その中には vue ベース、react ベース、thinkPHP ベース、laravel ベースのものもあります。やりすぎると、既存のアーキテクチャについてさまざまな考えが生まれ、良い点もあれば悪い点も出てきます。つまり、まだ使い心地が良くありません。 vue-cli (特に vue-cli v3.0) はすぐに構築して使用できますが、webpack は @vue/cli の SDK に封入されているため、よりクリーンで簡潔に使用できます。 @vue/cli的sdk里了,用起来更加干净、简洁。

好了,介绍完毕,接下来,我就从零开始,一步一步建起前后端完全分离的前端架构了。

步骤

由于要介绍的很多,全写在一篇里,有些太长了。

所以,我会分为:

  1. 创建开发环境下的webpack配置文件

  2. 配置eslint、babel、postcss

  3. 创建项目文件、目录架构

  4. 通过koa实现本地数据接口模拟

  5. 创建发布环境下的webpack配置文件

  6. 创建测试环境下的webpack配置文件、以及测试用例 (TODO)

  7. 自动初始化构建项目(TODO)

这七篇来分别介绍。

开发

一、初始化项目

  1. 创建项目文件夹

我们就叫vue-construct

  1. 初始化git

git init

  1. 初始化npm

npm init

  1. 创建项目文件

为了能让webpack跑起来,而不是一口气只讲配置而不运行一下,那样未免有些空洞,所以我们先创建一点项目文件和目录。
在这之前我们先安装两个包:vue、vue-router, npm i -S vue vue-router
我们将项目代码相关文件都放在名为app

さて、導入は終わりました。次に、ゼロから始めて、フロントエンドとバックエンドを完全に分離したフロントエンドアーキテクチャを段階的に構築していきます。

手順紹介するものがたくさんあるので、少し長くなってしまったので1つの記事にまとめて書きます。 開発環境でwebpackの設定ファイルを作成 プロジェクトファイルとディレクトリ構造の作成 テスト環境でWebpack設定ファイルを作成し、テストケース(TODO)npmを初期化します webpackを実行するには、設定について一度に話すのではなく、実行すると少し空になるので、最初にいくつかのプロジェクト ファイルとディレクトリを作成しましょう。
この前に、まず vue と vue-router の 2 つのパッケージ、npm i -S vue vue-router をインストールします。
すべてのプロジェクト コード関連ファイルは、app という名前のフォルダーに配置します。まずは全部作ってから、一つずつ紹介していきます。
├── app
│   ├── app.vue
│   ├── common
│   │   ├── img
│   │   ├── js
│   │   └── scss
│   ├── index.html
│   ├── index.js
│   ├── router
│   │   └── index.js
│   └── views
│       └── home
│           └── index.vue
├── .gitignore
├── package-lock.json
├── package.json
└── webpack.config.js
ということで、
eslint、babel、postcssの設定
ローカルデータの実装koaインターフェイスシミュレーションによる
リリース環境でWebpack設定ファイルを作成
ビルドプロジェクトの自動初期化(TODO)
この7つ それぞれの記事を個別にご紹介します。 developments1。
npm init
プロジェクトファイルを作成します
node_modules は無視されます。

    ファイル/フォルダー
  1. 目的

app.vue

vueのメインファイルとして

common

公開コードを入れる

  1. index.html

  2. ページテンプレートファイル

index.js

    プロジェクトメインエントリファイル
  1. router
  2. vueに対応するルーターファイルを置く

  3. views

  4. ビューファイルを置く

.gitignore node_module を無視する

🎜 🎜🎜🎜今のところ、これらのファイル内の特定のコードについては気にしません。それについては、webpack が設定された後に説明します。 🎜🎜2. webpack.config.js を設定します🎜🎜🎜🎜一連のパッケージをインストールします: 🎜🎜🎜🎜webpack を実行するには、🎜
webpack
webpack-dev-server
をインストールする必要があります🎜 vue 単一ページ ファイルを処理するには、次をインストールします: 🎜
vue-loader
🎜 scss ファイルを処理し、js から抽象化するには、次をインストールします: 🎜
node-sass
style-loader
css-loader
sass-loader
vue-style-loader
postcss
postcss-loader
autoprefixer
extract-text-webpack-plugin
🎜 画像とフォント ファイルを処理するには、次をインストールします: 🎜
file-loader
url-loader
🎜 高度な syntax-babel をサポートするには、次をインストールします: 🎜
babel
babel-loader
babel-plugin-syntax-dynamic-import
babel-plugin-transform-object-rest-spread
babel-polyfill
babel-preset-env
🎜 検証するにはcode format-eslint、インストール: 🎜
eslint
eslint-loader
eslint-plugin-html
babel-eslint
🎜🎜🎜 webpack.config.js ファイルの構成🎜🎜🎜
const webpack = require('webpack')
const path = require('path')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin')
// 为了抽离出两份CSS,创建两份ExtractTextPlugin
// base作为基础的css,基本不变,所以,可以抽离出来充分利用浏览器缓存
// app作为迭代的css,会经常改变
const isProduction = process.env.NODE_ENV === 'production'
const ExtractTextPlugin = require('extract-text-webpack-plugin')
const extractBaseCSS =
  new ExtractTextPlugin(
    {
      filename:'static/css/base.[chunkhash:8].css',
      allChunks: true,
      disable: !isProduction // 开发环境下不抽离css
    }
  )
const extractAppCSS
  = new ExtractTextPlugin(
    {
      filename:'static/css/app.[chunkhash:8].css',
      allChunks: true,
      disable: !isProduction // 开发环境下不抽离css
    }
  )

// 减少路径书写
function resolve(dir) {
  return path.join(__dirname, dir)
}

// 网站图标配置
const favicon = resolve('favicon.ico')

// __dirname: 总是返回被执行的 js 所在文件夹的绝对路径
// __filename: 总是返回被执行的 js 的绝对路径
// process.cwd(): 总是返回运行 node 命令时所在的文件夹的绝对路径
const config = {
  // sourcemap 模式
  devtool: 'cheap-module-eval-source-map',
  // 入口
  entry: {
    app: [
      'babel-polyfill', // 这里是配合babel-present-env导入的动态babel-polyfill,因此npm需dev依赖
      resolve('app/index.js')
    ]
  },
  // 输出
  output: {
    path: resolve('dev'),
    filename: 'index.bundle.js'
  },
  resolve: {
    // 扩展名,比如import 'app.vue',扩展后只需要写成import 'app'就可以了
    extensions: ['.js', '.vue', '.scss', '.css'],
    // 取路径别名,方便在业务代码中import
    alias: {
      api: resolve('app/api/'),
      common: resolve('app/common/'),
      views: resolve('app/views/'),
      components: resolve('app/components/'),
      componentsBase: resolve('app/componentsBase/'),
      directives: resolve('app/directives/'),
      filters: resolve('app/filters/'),
      mixins: resolve('app/mixins/')
    }
  },
  // loaders处理
  module: {
    rules: [
      {
        test: /\.js$/,
        include: [resolve('app')],
        loader: [
          'babel-loader',
          'eslint-loader'
        ]
      },
      {
        test: /\.vue$/,
        exclude: /node_modules/,
        loader: 'vue-loader',
        options: {
          extractCSS: true,
          loaders: {
            scss: extractAppCSS.extract({
              fallback: 'vue-style-loader',
              use: [
                {
                  loader: 'css-loader',
                  options: {
                    sourceMap: true
                  }
                },
                {
                  loader: 'postcss-loader',
                  options: {
                    sourceMap: true
                  }
                },
                {
                  loader: 'sass-loader',
                  options: {
                    sourceMap: true
                  }
                }
              ]
            })
          }
        }
      },
      {
        test: /\.(css|scss)$/,
        use: extractBaseCSS.extract({
          fallback: 'style-loader',
          use: [
            {
              loader: 'css-loader',
              options: {
                sourceMap: true
              }
            },
            {
              loader: 'postcss-loader',
              options: {
                sourceMap: true
              }
            },
            {
              loader: 'sass-loader',
              options: {
                sourceMap: true
              }
            }
          ]
        })
      },
      {
        test: /\.(png|jpe?g|gif|svg|ico)(\?.*)?$/,
        loader: 'url-loader',
        options: {
          limit: 8192,
          name: isProduction
            ? 'static/img/[name].[hash:8].[ext]'
            : 'static/img/[name].[ext]'
        }
      },
      {
        test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
        loader: 'url-loader',
        options: {
          limit: 8192,
          name: isProduction
            ? 'static/font/[name].[hash:8].[ext]'
            : 'static/font/[name].[ext]'
        }
      }
    ]
  },
  plugins: [
    // html 模板插件
    new HtmlWebpackPlugin({
      favicon,
      filename: 'index.html',
      template: resolve('app/index.html')
    }),
    // 抽离出css
    extractBaseCSS,
    extractAppCSS,
    // 热替换插件
    new webpack.HotModuleReplacementPlugin(),
    // 更友好地输出错误信息
    new FriendlyErrorsPlugin()
  ],
  devServer: {
    proxy: {
      // 凡是 `/api` 开头的 http 请求,都会被代理到 localhost:7777 上,由 koa 提供 mock 数据。
      // koa 代码在 ./mock 目录中,启动命令为 npm run mock。
      '/api': {
        target: 'http://localhost:7777', // 如果说联调了,将地址换成后端环境的地址就哦了
        secure: false
      }
    },
    host: '0.0.0.0',
    port: '9999',
    disableHostCheck: true, // 为了手机可以访问
    contentBase: resolve('dev'), // 本地服务器所加载的页面所在的目录
    // historyApiFallback: true, // 为了SPA应用服务
    inline: true, //实时刷新
    hot: true  // 使用热加载插件 HotModuleReplacementPlugin
  }
}

module.exports = {
  config: config,
  extractBaseCSS: extractBaseCSS,
  extractAppCSS: extractAppCSS
}
🎜概要🎜🎜この記事では主に 3 つのことを行います:🎜🎜🎜🎜 簡単なプロジェクト構造を作成する🎜🎜🎜🎜インストール後この記事と後で npm を使用する パッケージ 🎜🎜🎜🎜開発環境用に Webpack を構成する🎜🎜🎜🎜 関連する推奨事項: 🎜🎜🎜VUE フロントエンド Cookie 簡単な操作例の共有🎜🎜

以上がVue フロントエンド アーキテクチャの学習 (1)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。