{"id":32510,"date":"2024-11-25T12:04:18","date_gmt":"2024-11-25T04:04:18","guid":{"rendered":"https:\/\/fwq.ai\/blog\/32510\/"},"modified":"2024-11-25T12:04:18","modified_gmt":"2024-11-25T04:04:18","slug":"mpvue%e4%b8%adsass%e5%85%a8%e5%b1%80%e5%8f%98%e9%87%8f%e7%9a%84%e9%85%8d%e7%bd%ae%e6%96%b9%e6%b3%95%ef%bc%88%e4%bb%a3%e7%a0%81%ef%bc%89","status":"publish","type":"post","link":"https:\/\/fwq.ai\/blog\/32510\/","title":{"rendered":"mpvue\u4e2dsass\u5168\u5c40\u53d8\u91cf\u7684\u914d\u7f6e\u65b9\u6cd5\uff08\u4ee3\u7801\uff09"},"content":{"rendered":"<p>\u672c\u7bc7\u6587\u7ae0\u7ed9\u5927\u5bb6\u5e26\u6765\u7684\u5185\u5bb9\u662f\u5173\u4e8empvue\u4e2dsass\u5168\u5c40\u53d8\u91cf\u7684\u914d\u7f6e\u65b9\u6cd5\uff08\u4ee3\u7801\uff09\uff0c\u6709\u4e00\u5b9a\u7684\u53c2\u8003\u4ef7\u503c\uff0c\u6709\u9700\u8981\u7684\u670b\u53cb\u53ef\u4ee5\u53c2\u8003\u4e00\u4e0b\uff0c\u5e0c\u671b\u5bf9\u4f60\u6709\u6240\u5e2e\u52a9\u3002<\/p>\n<p><strong>\u5b89\u88c5loader<\/strong><\/p>\n<pre>cnpm i sass-loader sass-resources-loader --save-dev<\/pre>\n<p>  \u767b\u5f55\u540e\u590d\u5236   <\/p>\n<p><strong>\u4fee\u6539\u6839\u76ee\u5f55\u4e0b\/build\/utils.js<\/strong><\/p>\n<pre>var path = require('path')\nvar config = require('..\/config')\nvar ExtractTextPlugin = require('extract-text-webpack-plugin')\n\nexports.assetsPath = function (_path) {\n  var assetsSubDirectory = process.env.NODE_ENV === 'production'\n    ? config.build.assetsSubDirectory\n    : config.dev.assetsSubDirectory\n  return path.posix.join(assetsSubDirectory, _path)\n}\n\nexports.cssLoaders = function (options) {\n  options = options || {}\n\n  var cssLoader = {\n    loader: 'css-loader',\n    options: {\n      minimize: process.env.NODE_ENV === 'production',\n      sourceMap: options.sourceMap\n    }\n  }\n\n  var postcssLoader = {\n    loader: 'postcss-loader',\n    options: {\n      sourceMap: true\n    }\n  }\n\n  var px2rpxLoader = {\n    loader: 'px2rpx-loader',\n    options: {\n      baseDpr: 1,\n      rpxUnit: 0.5\n    }\n  }\n  \/\/\u6dfb\u52a0\u8be5\u9879\n  var sassResourceLoader = {\n    loader: 'sass-resources-loader',\n    options: {\n      resources: [\n      \/\/\u4fee\u6539\u76f8\u5e94\u8def\u5f84\n        path.resolve(__dirname, '..\/src\/styles\/index.scss'),\n      ]\n    }\n  }\n  \/\/\u6dfb\u52a0\u8be5\u9879\n\n  \/\/ generate loader string to be used with extract text plugin\n  function generateLoaders (loader, loaderOptions, anotherLoader) {\n    var loaders = [cssLoader, px2rpxLoader, postcssLoader]\n    if (loader) {\n      loaders.push({\n        loader: loader + '-loader',\n        options: Object.assign({}, loaderOptions, {\n          sourceMap: options.sourceMap\n        })\n      })\n    }\n\n    if(!!anotherLoader) loaders.push(anotherLoader);\n\n    \/\/ Extract CSS when that option is specified\n    \/\/ (which is the case during production build)\n    if (options.extract) {\n      return ExtractTextPlugin.extract({\n        use: loaders,\n        fallback: 'vue-style-loader'\n      })\n    } else {\n      return ['vue-style-loader'].concat(loaders)\n    }\n  }\n\n  \/\/ https:\/\/vue-loader.vuejs.org\/en\/configurations\/extract-css.html\n  return {\n    css: generateLoaders(),\n    wxss: generateLoaders(),\n    postcss: generateLoaders(),\n    less: generateLoaders('less'),\n    \/\/\u4fee\u6539\n    sass: generateLoaders('sass', { indentedSyntax: true },sassResourceLoader),\n    scss: generateLoaders('sass',{},sassResourceLoader),\n    \/\/\u4fee\u6539\n    stylus: generateLoaders('stylus'),\n    styl: generateLoaders('stylus')\n  }\n}\n\n\/\/ Generate loaders for standalone style files (outside of .vue)\nexports.styleLoaders = function (options) {\n  var output = []\n  var loaders = exports.cssLoaders(options)\n  for (var extension in loaders) {\n    var loader = loaders[extension]\n    output.push({\n      test: new RegExp('\\.' + extension + '$'),\n      use: loader\n    })\n  }\n  return output\n}<\/pre>\n<p>  \u767b\u5f55\u540e\u590d\u5236   <\/p>\n<p>\u4ee5\u4e0a\u5c31\u662fmpvue\u4e2dsass\u5168\u5c40\u53d8\u91cf\u7684\u914d\u7f6e\u65b9\u6cd5\uff08\u4ee3\u7801\uff09\u7684\u8be6\u7ec6\u5185\u5bb9\uff0c\u66f4\u591a\u8bf7\u5173\u6ce8\u7c73\u4e91\u5176\u5b83\u76f8\u5173\u6587\u7ae0\uff01<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u672c\u7bc7\u6587\u7ae0\u7ed9\u5927\u5bb6\u5e26\u6765\u7684\u5185\u5bb9\u662f\u5173\u4e8empvue\u4e2dsass\u5168\u5c40\u53d8\u91cf\u7684\u914d\u7f6e\u65b9\u6cd5\uff08\u4ee3\u7801\uff09\uff0c\u6709\u4e00\u5b9a\u7684\u53c2\u8003\u4ef7\u503c\uff0c\u6709\u9700\u8981\u7684\u670b\u53cb\u53ef\u4ee5\u53c2\u8003\u4e00\u4e0b\uff0c\u5e0c\u671b\u5bf9\u4f60\u6709\u6240\u5e2e\u52a9\u3002 \u5b89\u88c5loader cnpm i sass-loader sass-resources-loader &#8211;save-dev \u767b\u5f55\u540e\u590d\u5236 \u4fee\u6539\u6839\u76ee\u5f55\u4e0b\/build\/utils.js var path = require(&#8216;path&#8217;) var config = require(&#8216;..\/config&#8217;) var ExtractTextPlugin = require(&#8216;extract-text-webpack-plugin&#8217;) exports.assetsPath = function (_path) { var assetsSubDirectory = process.env.NODE_ENV === &#8216;production&#8217; ? config.build.assetsSubDirectory : config.dev.assetsSubDirectory return path.posix.join(assetsSubDirectory, _path) } exports.cssLoaders = function (options) { options = options || {} var cssLoader = { loader: [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[19],"tags":[],"class_list":["post-32510","post","type-post","status-publish","format-standard","hentry","category-19"],"_links":{"self":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/32510","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/comments?post=32510"}],"version-history":[{"count":0,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/32510\/revisions"}],"wp:attachment":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/media?parent=32510"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/categories?post=32510"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/tags?post=32510"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}