css-loader.conf.js 2.5 KB
Newer Older
1 2 3
const fs = require('fs')
const path = require('path')

fxy060608's avatar
fxy060608 已提交
4
const {
5 6
  getPlatformScss,
  getPlatformSass,
fxy060608's avatar
fxy060608 已提交
7 8 9
  nvueCssPreprocessOptions
} = require('@dcloudio/uni-cli-shared')

10 11 12 13
const {
  sassLoaderVersion
} = require('@dcloudio/uni-cli-shared/lib/scss')

fxy060608's avatar
fxy060608 已提交
14 15 16 17 18 19 20 21 22 23 24 25 26
const nvueStyleLoader = {
  loader: '@dcloudio/vue-cli-plugin-hbuilderx/packages/webpack-uni-nvue-loader/lib/style'
}

const preprocessLoader = {
  loader: '@dcloudio/vue-cli-plugin-uni/packages/webpack-preprocess-loader',
  options: nvueCssPreprocessOptions
}

const postcssLoader = {
  loader: 'postcss-loader',
  options: {
    sourceMap: false,
27 28 29 30
    parser: require('postcss-comment'),
    plugins: [
      require('postcss-import'),
      require('@dcloudio/vue-cli-plugin-uni/packages/postcss')
fxy060608's avatar
fxy060608 已提交
31 32 33 34
    ]
  }
}

35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
// sass 全局变量
const isSass = fs.existsSync(path.resolve(process.env.UNI_INPUT_DIR, 'uni.sass'))
const isScss = fs.existsSync(path.resolve(process.env.UNI_INPUT_DIR, 'uni.scss'))
let sassData = isSass ? getPlatformSass() : getPlatformScss()

if (isSass) {
  sassData = `@import "@/uni.sass"`
} else if (isScss) {
  sassData = `${sassData}
  @import "@/uni.scss";`
}

const scssLoader = {
  loader: 'sass-loader',
  options: {
    sourceMap: false
  }
}

fxy060608's avatar
fxy060608 已提交
54 55 56
const sassLoader = {
  loader: 'sass-loader',
  options: {
57 58 59 60 61 62 63 64 65 66 67 68 69
    sourceMap: false
  }
}

if (sassLoaderVersion < 8) {
  scssLoader.options.data = sassData
  sassLoader.options.data = sassData
  sassLoader.options.indentedSyntax = true
} else {
  scssLoader.options.prependData = sassData
  sassLoader.options.prependData = sassData
  sassLoader.options.sassOptions = {
    indentedSyntax: true
fxy060608's avatar
fxy060608 已提交
70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
  }
}

const lessLoader = {
  loader: 'less-loader',
  options: {
    sourceMap: false
  }
}

const stylusLoader = {
  loader: 'stylus-loader',
  options: {
    sourceMap: false,
    preferPathResolver: 'webpack'
  }
}

88
function createOneOf (preLoader) {
fxy060608's avatar
fxy060608 已提交
89 90 91
  const use = [
    nvueStyleLoader,
    preprocessLoader
92
  ]
fxy060608's avatar
fxy060608 已提交
93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
  use.push(postcssLoader)
  if (preLoader) {
    use.push(preLoader)
  }
  use.push(preprocessLoader)

  return [{
    resourceQuery: /\?vue/,
    use
  },
  {
    use
  }
  ]
}

module.exports = [{
  test: /\.css$/,
  oneOf: createOneOf()
}, {
  test: /\.scss$/,
114
  oneOf: createOneOf(scssLoader)
fxy060608's avatar
fxy060608 已提交
115 116 117 118 119 120 121 122 123 124
}, {
  test: /\.sass$/,
  oneOf: createOneOf(sassLoader)
}, {
  test: /\.less$/,
  oneOf: createOneOf(lessLoader)
}, {
  test: /\.styl(us)?$/,
  oneOf: createOneOf(stylusLoader)
}]