10

Webpack ビルドで Vuecli から生成された Vue を使用する。たくさんの魔法が起こっています。私が理解できないのは、IE に必要なベンダー プレフィックスを生成する方法です。

これは github の問題からコピーされました: https://github.com/vuejs-templates/webpack/issues/421#issuecomment-284322065

vue-loader.conf.js

var utils = require('./utils')
var config = require('../config')
var isProduction = process.env.NODE_ENV === 'production'
 
module.exports = {
  loaders: utils.cssLoaders({
    sourceMap: isProduction
      ? config.build.productionSourceMap
      : config.dev.cssSourceMap,
    extract: isProduction
  }),
  postcss: [
    require('postcss-import')(),
    require('autoprefixer')({
      browsers: ['ie >= 9']
    })
  ]
}

シンプルなコンテナ コンポーネントの例

コンテナー/index.vue

<template>
    <div class="container">
        <slot></slot>
    </div>
</template>
<script>
    import './index.scss'
    export default {}
</script>

コンテナー/index.scss

// this is aliased in webpack.base.conf
@import "~styles/base-config";

.container {
  @include grid(); // this generates display:flex and border-box resets
  max-width: 100%;
  margin: 0 auto;
}

予期されるインライン出力が head で生成されます (ただし、現在は -ms-flexbox または -webkit- prefixes を取得しません)

<style> 
.container {
   -webkit-box-sizing: border-box; // not generated
   box-sizing: border-box; 
   display: -webkit-box;  // not generated
   display: -ms-flexbox; // not generated
   display: flex;
   max-width: 100%;
   margin: 0 auto;
}
</style>

関連している:

  1. scss ファイルが必要な場合、webpack2 vue-cli autoprefixer は js ファイルで動作しませんか?</a>

  2. https://github.com/vuejs/vue-cli/issues/350 vue-loader.conf.js の autoprefixer を最後の 2 つのバージョンで使用するだけです (使用しましbrowsers: ['ie >= 9']たが、機能しませんでした)。

  3. 潜在的な解決策: https://github.com/vuejs-templates/webpack/issues/600 ただし、コンソールでソース マップ エラーが発生します。

build/utils.js に追加

// npm install postcss-loader first then edit:
...
  var postcssLoader = {
    loader : 'postcss-loader'
  }

  // generate loader string to be used with extract text plugin
  function generateLoaders (loader, loaderOptions) {
    var loaders = [cssLoader, postcssLoader]
    if (loader) {
      loaders.push({
        loader: loader + '-loader',
        options: Object.assign({}, loaderOptions, {
          sourceMap: options.sourceMap
        })
      })
    }
...

更新 26-07-2017

ここにレポを追加しました: https://github.com/sidouglas/vue-js-vendor-prefixes-bug

更新 03-08-2017

@クリス・カマラッタ

npm ERR! fetch failed http://remote-server/artifactory/api/npm/npm-aggregator/vue/-/vue-2.4.2.tgz
npm WARN retry will retry, error on last attempt: Error: getaddrinfo ENOTFOUND uscavs-repo1 remote-server
npm ERR! fetch failed http://remote-server/artifactory/api/npm/npm-aggregator/vue-router/-/vue-router-2.7.0.tgz
npm WARN retry will retry, error on last attempt: Error: getaddrinfo ENOTFOUND uscavs-repo1 remote-server
cloneCurrentTree: WARN retry will retry, error on last attempt: Error: getaddrinfo ENOTFOUND uscavs-repo1 remote-server
[2]  + 56232 suspended  npm i
4

1 に答える 1