前言
之前已经介绍过了Vue + Webpack + Vue-loader的相关功能介绍,大家可以点击这篇文章了解详情。下面就来看看相关配置篇,感兴趣的可以参考学习。
使用预处理器
在 Webpack 中,所有的预处理器需要和一个相应的加载器一同使用。vue-loader 允许你用其它的 Webpack 加载器去处理 Vue 组件一部分代码。它会根据 lang 属性自动用适当的加载器去处理。
CSS
例如,我们编译用 SASS 编译 <style> 标签:
npm install sass-loader node-sass --save-dev
<style lang="sass"> /* 这里写一些 sass 代码 */ </style>
在引擎内,首先,<style> 标签内的内容会被 sass-loader 编译,然后再被进一步处理。
JavaScript
默认情况下,Vue 组件内的所有 JavaScript 会被 babel-loader 处理。当然,你也可以更改:
npm install coffee-loader --save-dev
<script lang="coffee"> # 这里写一些 coffeescript! </script>
Templates
处理模板的过程有点不同,因为大多 Webpack 模板加载器(比如 jade-loader )会返回一个模板处理函数,而不是被编译过的 HTML 字符串。我们只要安装 jade ,而不是 jade-loader :
npm install jade --save-dev
<template lang="jade"> div h1 Hello world! </template>
重要提示: 如果你使用 vue-loader@<8.2.0, 你也需要安装 template-html-loader.
内联加载请求
在 lang 属性上,你能使用 Webpack loader requests :
<style lang="sass?outputStyle=expanded"> /* use sass here with expanded output */ </style>
但是,注意这样只适用特定的 Webpack,并不兼容 Browserify 和 vueify。 如果你想让你的 Vue 组件发布成一个第三方组件的话,避免这样使用
URL资源处理
默认情况,vue-loader 是自动用 css-loader 和 Vue 组件编译器来处理样式和模板文件的。在处理过程中,所有的资源 URL 比如<img src="..."> , background: url(...) 和 CSS @import 都是被当做依赖的模块来处理。
例如,url(./image.png) 被转译成 require('./image.png') 。
<img src="../image.png">
如上会被再转译成:
createElement('img', { attrs: { src: require('../image.png') }})
因为 .png 并不是个 JavaScript 文件,你需要配置 Webpack 使用 file-loader 或者 url-loader 处理它们。项目脚手架工具 vue-cli 也能帮你配置这些。
这样做的好处是:
加载器高级配置
若你想自定义载器的配置,不要 vue-loader 来推断。 或你只想覆盖加载器内置的配置。 那就这样做,在你 Webpack 配置文件里,添加一个 vue 块,并指定 loaders 选项:
Webpack 1.x Example:
// webpack.config.js module.exports = { // other options... module: { loaders: [ { test: /\.vue$/, loader: 'vue' } ] }, // vue-loader 配置 vue: { // ... 其他 vue 选项 loaders: { // 用 coffee-loader 加载所有没有 "lang" 属性的 <script> js: 'coffee', // 直接把 <template> 作为 HTML 字符串来加载,不需先用 vue-html-loader 处理。 html: 'raw' } } }
Webpack 2.x (^2.1.0-beta.25):
module.exports = { // 其他选项... module: { // module.rules 是和版本1.x中的 module.loaders 是相同的 rules: [ { test: /\.vue$/, loader: 'vue', // vue-loader 选项在这里配置 options: { loaders: { // ... } } } ] } }
这里是个实际的加载器配置高级用法的实例 提取组件内的 CSS 到单独文件。
提取CSS到单独文件
如下是提取所有程序的 Vue 组件中的 CSS 到一个单独的 CSS 文件的配置:
Webpack 1.x
npm install extract-text-webpack-plugin --save-dev
// webpack.config.js var ExtractTextPlugin = require("extract-text-webpack-plugin") module.exports = { // other options... module: { loaders: [ { test: /\.vue$/, loader: 'vue' }, ] }, vue: { loaders: { css: ExtractTextPlugin.extract("css"), // 你也能包含 <style lang="less"> 或其他语言 less: ExtractTextPlugin.extract("css!less") } }, plugins: [ new ExtractTextPlugin("style.css") ] }
Webpack 2.x (^2.1.0-beta.25)
npm install extract-text-webpack-plugin@2.x --save-dev
// webpack.config.js var ExtractTextPlugin = require("extract-text-webpack-plugin") module.exports = { // 其他选项... module: { rules: [ { test: /\.vue$/, loader: 'vue', options: { loaders: { css: ExtractTextPlugin.extract({ loader: 'css-loader', fallbackLoader: 'vue-style-loader' // <- this is a dep of vue-loader, so no need to explicitly install if using npm3 }) } } } ] }, plugins: [ new ExtractTextPlugin("style.css") ] }
总结
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对小牛知识库的支持。
本文向大家介绍vue-loader教程介绍,包括了vue-loader教程介绍的使用技巧和注意事项,需要的朋友参考一下 在最初使用webpack+vue时,看到vue里面各种语法,包括import,export,html和css的写作方式,我都能依葫芦画瓢地实现各种功能,但是为什么能这样写,一直不太理解,直到我了解了vue-loader。 vue-loader功能 如图,webpack的功能就是将
vue官方模板的设置是last 2 versions,可能会导致你在某些Android机子上出现问题。 如果你使用 last 7 versions 会生成不必要的-ms前缀代码. 因此建议同WeUI一样,使用配置 ['iOS >= 7', 'Android >= 4.1'] 直接在 vux-loader 里配置 如果你没有在 postcss 里配置,你可以直接配置 vux-loader 的 dup
本文向大家介绍vue+eslint+vscode配置教程,包括了vue+eslint+vscode配置教程的使用技巧和注意事项,需要的朋友参考一下 package.json文件所需要的eslint包 执行npm install安装好这些依赖包 在项目中添加两个文件 自行配置eslint检查时所忽略的文件 完成后在目录中的结果 vscode+eslint配置 我这里是使用vscode进行检查因此还需
本文向大家介绍webpack构建vue项目的详细教程(配置篇),包括了webpack构建vue项目的详细教程(配置篇)的使用技巧和注意事项,需要的朋友参考一下 最近公司要求用vue重构项目,还涉及到模块化开发,于是乎,我专门花了几天的时间研究了一下webpack这个目前来看比较热门的模块加载兼打包工具,发现上手并不是很容易,现将总结的一些有关配置的心得分享出来,欢迎大神来拍砖。。。 一、新建一个项
本文向大家介绍Pycharm学习教程(4) Python解释器的相关配置,包括了Pycharm学习教程(4) Python解释器的相关配置的使用技巧和注意事项,需要的朋友参考一下 Python解释器的相关配置,供大家参考,具体内容如下 1、准备工作 (1)Pycharm版本为3.4或者更高。 (2)电脑上至少已经安装了一个Python解释器。 (3)如果你希望配置一个远程解释器,则需要
本文向大家介绍spring cloud学习入门之config配置教程,包括了spring cloud学习入门之config配置教程的使用技巧和注意事项,需要的朋友参考一下 前言 本文主要给大家分享了关于spring cloud的入门教程,主要介绍了config配置的相关内容,下面话不多说了,来一起看看看详细的介绍吧。 简介 Spring cloud config 分为两部分 server clie
本文向大家介绍vue学习之Vue-Router用法实例分析,包括了vue学习之Vue-Router用法实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了vue学习之Vue-Router用法。分享给大家供大家参考,具体如下: Vue-router就像一个路由器,将组件(components)映射到路由(routes)后,通过点击<router-link>它可以在<router-view
在学习webpack之前,先来聊聊webpack产生背景、解决的问题以及后期学习中需要提前说好的规范 webpack产生的背景: 1、多js文件下全局对象冲突 2、模块加载顺序 3、解决模块或库的依赖 4、大工程模块过多,难以管理 webpack的作用: 1、将所有的依赖拆分成块且按需加载 2、首屏加载耗时少 3、所有的静态文件都是一个模块(css和图片等静态文件) 4、第三方库也可以作为一个模块