vue单页面模板说明文档(2)
Linter Configuration
This boilerplate uses ESLint as the linter, and uses the Standard preset with some small customizations.
If you are not happy with the default linting rules, you have several options:
Overwrite individual rules in
.eslintrc.js. For example, you can add the following rule to enforce semicolons instead of omitting them:// .eslintrc.js
"semi": [, "always"]Pick a different ESLint preset when generating the project, for example eslint-config-airbnb.
Pick "none" for ESLint preset when generating the project and define your own rules. See ESLint documentation for more details.
Pre-Processors
This boilerplate has pre-configured CSS extraction for most popular CSS pre-processors including LESS, SASS, Stylus, and PostCSS. To use a pre-processor, all you need to do is installing the appropriate webpack loader for it. For example, to use SASS:
npm install sass-loader node-sass --save-dev
Note you also need to install
node-sassbecausesass-loaderdepends on it as a peer dependency.Using Pre-Processors inside Components
Once installed, you can use the pre-processors inside your
*.vuecomponents using thelangattribute on<style>tags:<style lang="scss">
/* write SASS! */
</style>A note on SASS syntax
lang="scss"corresponds to the CSS-superset syntax (with curly braces and semicolons).lang="sass"corresponds to the indentation-based syntax.
PostCSS
Styles in
*.vuefiles are piped through PostCSS by default, so you don't need to use a specific loader for it. You can simply add PostCSS plugins you want to use inbuild/webpack.base.conf.jsunder thevueblock:// build/webpack.base.conf.js
module.exports = {
// ...
vue: {
postcss: [/* your plugins */]
}
}See vue-loader's related documentation for more details.
Standalone CSS Files
To ensure consistent extraction and processing, it is recommended to import global, standalone style files from your root
App.vuecomponent, for example:<!-- App.vue -->
<style src="./styles/global.less" lang="less"></style>Note you should probably only do this for the styles written by yourself for your application. For existing libraries e.g. Bootstrap or Semantic UI, you can place them inside
/staticand reference them directly inindex.html. This avoids extra build time and also is better for browser caching. (See Static Asset Handling)Handling Static Assets
You will notice in the project structure we have two directories for static assets:
src/assetsandstatic/. What is the difference between them?Webpacked Assets
To answer this question, we first need to understand how Webpack deals with static assets. In
*.vuecomponents, all your templates and CSS are parsed byvue-html-loaderandcss-loaderto look for asset URLs. For example, in<img src="./logo.png">andbackground: url(./logo.png),"./logo.png"is a relative asset path and will be resolved by Webpack as a module dependency.Because
logo.pngis not JavaScript, when treated as a module dependency, we need to useurl-loaderandfile-loaderto process it. This boilerplate has already configured these loaders for you, so you basically get features such as filename fingerprinting and conditional base64 inlining for free, while being able to use relative/module paths without worrying about deployment.Since these assets may be inlined/copied/renamed during build, they are essentially part of your source code. This is why it is recommended to place Webpack-processed static assets inside
/src, along side other source files. In fact, you don't even have to put them all in/src/assets: you can organize them based on the module/component using them. For example, you can put each component in its own directory, with its static assets right next to it.Asset Resolving Rules
Relative URLs, e.g.
./assets/logo.pngwill be interpreted as a module dependency. They will be replaced with an auto-generated URL based on your Webpack output configuration.Non-prefixed URLs, e.g.
assets/logo.pngwill be treated the same as the relative URLs and translated into./assets/logo.png.URLs prefixed with
~are treated as a module request, similar torequire('some-module/image.png'). You need to use this prefix if you want to leverage Webpack's module resolving configurations. For example if you have a resolve alias forassets, you need to use<img src="~assets/logo.png">to ensure that alias is respected.Root-relative URLs, e.g.
/assets/logo.pngare not processed at all.
Getting Asset Paths in JavaScript
In order for Webpack to return the correct asset paths, you need to use
require('./relative/path/to/file.jpg'), which will get processed byfile-loaderand returns the resolved URL. For example:computed: {
background () {
return require('./bgs/' + this.id + '.jpg')
}
}Note the above example will include every image under
./bgs/in the final build. This is because Webpack cannot guess which of them will be used at runtime, so it includes them all."Real" Static Assets
In comparison, files in
static/are not processed by Webpack at all: they are directly copied to their final destination as-is, with the same filename. You must reference these files using absolute paths, which is determined by joiningbuild.assetsPublicPathandbuild.assetsSubDirectoryinconfig.js.As an example, with the following default values:
// config/index.js
module.exports = {
// ...
build: {
assetsPublicPath: '/',
assetsSubDirectory: 'static'
}
}Any file placed in
static/should be referenced using the absolute URL/static/[filename]. If you changeassetSubDirectorytoassets, then these URLs will need to be changed to/assets/[filename].We will learn more about the config file in the section about backend integration.
vue单页面模板说明文档(2)的更多相关文章
- vue单页面模板说明文档(3)
Environment Variables Sometimes it is practical to have different config values according to the env ...
- vue单页面模板说明文档(1)
Introduction This boilerplate is targeted towards large, serious projects and assumes you are somewh ...
- vue render {} 对象 说明文档
Vue学习笔记进阶篇——Render函数 http://www.mamicode.com/info-detail-1906336.html 深入data object参数 有一件事要注意:正如在模板语 ...
- Vue 单文件元件 — vTabs
简书原文 这是我做了第二个单文件元件 第一个在这里vCheckBox 这次这个叫vTabs,用于操作标签页 演示DEMO 演示DEMO2 - 子组件模式及别名 演示DEMO3 - 极简模式 示例: h ...
- webpack入坑之旅(五)加载vue单文件组件
这是一系列文章,此系列所有的练习都存在了我的github仓库中vue-webpack,在本人有了新的理解与认识之后,会对文章有不定时的更正与更新.下面是目前完成的列表: webpack入坑之旅(一)不 ...
- SWFUpload 2.5.0版 官方说明文档 中文翻译版
原文地址:http://www.cnblogs.com/youring2/archive/2012/07/13/2590010.html#setFileUploadLimit SWFUpload v2 ...
- 《暗黑世界GM管理后台系统》部署+功能说明文档
http://www.9miao.com/product-10-1073.html <暗黑世界GM管理后台系统>部署+功能说明文档 <暗黑世界GM管理后台系统>部署+功能说明文 ...
- BasicExcel说明文档
BasicExcel说明文档 BasicExcel原始链接:http://www.codeproject.com/Articles/13852/BasicExcel-A-Class-to-Read-a ...
- 处理 Vue 单页面应用 SEO 的另一种思路
vue-meta-info 官方地址: monkeyWangs/vue-meta-info (设置vue 单页面meta info信息,如果需要单页面SEO,可以和 prerender-spa-plu ...
随机推荐
- Elixir 单元测试
概述 elixir 中自带了单元测试框架 ExUnit ,其中提供单元测试的一系列,主要包含以下模块: ExUnit: 单元测试框架 ExUnit.Assertions: 断言 ExUnit.Case ...
- Java String、StringBuilder、StringBuffer[笔记]
String对象是字符串常量(创建之后不可更改),StringBuilder和StringBuffer对象是字符串变量(可更改),三者主要区别在于执行速度和线程安全. 执行速度 执行速度:String ...
- Java序列化(含transient)
什么是序列化? 我们创建的对象只有在Java虚拟机保持运行时,才会存在于内存中.如果想要超出Java虚拟机的生命周期,就可以将对象序列化,将对象状态转换为字节序列,写入文件(或socket传输),后面 ...
- 20个必不可少的Python库
转载:http://www.python123.org/tutorials/58b41f2a28c8f30100bd41dc 读者们好.今天我将介绍20个属于我常用工具的Python库,我相信你看完之 ...
- 前端使用node.js+express+mockjs+mysql实现简单服务端,2种方式模拟数据返回
今天,我教大家来搭建一个简单服务端 参考文章: https://www.jianshu.com/p/cb89d9ac635e https://www.cnblogs.com/jj-notes/p/66 ...
- DP h回文子串 LCS
题目背景 IOI2000第一题 题目描述 回文词是一种对称的字符串.任意给定一个字符串,通过插入若干字符,都可以变成回文词.此题的任务是,求出将给定字符串变成回文词所需要插入的最少字符数. 比如 “A ...
- A - Packets 贪心
A factory produces products packed in square packets of the same height h and of the sizes 1*1, 2*2, ...
- Java基础知识点(三)
前言:准备将Java基础知识点总结成一个系列,用于平常复习并加深理解.每篇尽量做到短小精悍,便于阅读. 1.Math类中相关函数 Math.floor(x):返回不大于x的最大整数.eg:Math.f ...
- windows下python2和python3共享
其实最好的解决方案使用 virtualenv http://pythonguidecn.readthedocs.io/zh/latest/dev/virtualenvs.html 不太好的方法,先安装 ...
- [POI2012]SZA-Cloakroom
嘟嘟嘟 一道比较有意思的dp. 这题关键在于状态的设计.如果像我一样令\(dp[i][j]\)表示选到第\(i\)个物品,\(\sum c\)能都等于\(j\)的话,那就是\(O(qnk)\)了,怒拿 ...