Vue相关知识点记录
1.安装
vue不支持ie8以下版本(无法模拟ECMAScript5特性),支持所有兼容ECMAScript5的浏览器。
浏览器安装Vue Devtools, 可以在更友好的界面中审查和调试Vue应用。
直接下载用script标签引入,Vue会被注册成一个全局变量。
开发环境不要使用压缩版本,否则没有常见错误的相关警告。生产环境使用压缩版本,是一个更小的构建,获得更快的速度体验。
用Vue构建大型应用时推荐使用NPM安装,它能很好的和谐webpack、Browserify模块打包器配合使用,
Vue提供了官方的CLI,为单页面应用(SPA)快速搭建繁杂的脚手架。(热重载,保存时lint校验,生产环境可用的构建版本)。
vue.js有多个构建版本(npm包的dist目录下)
a. 完成版:同时包含编译器和运行时的版本
b. 编译器:用来将模板字符串编译成JS渲染函数的代码
c. 运行时:用来创建Vue实例,渲染并处理虚拟Dom等的代码客户端编译模板(运行时+编译器),当使用vue-loader或vueify的时候,*.vue文件内部的模板会在构建时预编译成js。
最终打好的包里是不需要编译器的,只用运行时版本即可。(体积要比完成版体积小大约30%)
ps. 仍希望使用完整版配置,代码如下:
// webpack
module.exports = {
//..
resolve: {
alias: {
// webpack1时需用'vue/dist/vue.common.js'
'vue$': 'vue/dist/vue.esm.js'
}
}
}
// rollup
const alias = require('rollup-plugin-alias')
rollup({
//..
plugins: [
alias({
'vue': require.resolve('vue/dist/vue.esm.js')
})
]
})
// Browserify,添加到项目的package.json
{
// ..
"browser": {
"vue": "vue/dist/vue.comme.js"
}
}
// parcel,添加到项目的package.json
{
// ..
"alias": {
"vue": "./node_modules/vue/dist/vue.comme.js"
}
}
2.开发环境和生产环境的配置
UMD版本的开发环境/生产环境是硬编码好的,开发环境下用未压缩代码,生产环境下使用压缩代码。
CommonJs和ES Module版本用于打包工具,不提供压缩版本,需要自行压缩。
CommonJs和ES Module虽保留原始的process.env.NODE_ENV检测,以决定运行在什么模式下。但是我们应该使用适当的打包工具替换这个环境变量,来控制Vue运行的模式。
ps. 把process.env.NODE_ENV替换为字符串字面量可以让UglifyJS之类的压缩工具完全丢掉仅供开发环境的代码块,以减少最终文件尺寸.
// webpack4+,使用mode选项
module.exports = {
mode: 'production'
}
// webpack3及更低版本,使用DefinePlugin
var webpack = require('webpack');
module.exports = {
//..
plugins: [
//..
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: JSON.stringify('production')
}
})
]
}
// rollup使用rollup-plugin-replace
const replace = require('rollup-plugin-replace')
rollup({
//..
plugins: [
replace: ({
'process.env.NODE_ENV': JSON.stringify('production')
})
]
}).then(...)
// Browserify,为包应用一次全局的envify转换
NODE_ENV=production browserify -g envify -e main.js | uglifyjs -c -m > build.js
3.CSP环境
Google Chrome Apps,会强制应用内容安全策略(CSP),不能使用new Function()对表达式求值,这时可以用CSP兼容版本。完整版本依赖该功能编译模板,所以无法在这些环境下使用。
另一方面,运行时版本完全兼容CSP,当通过webpack+vue-loader或者Browserify+vueify构建时,模板将被编译为render函数,可以在CSP环境中完美执行。
4.开发版本(*)
Github仓库的/dist文件夹只有在新版本发布时才会提交,如果想要使用Github上VUE最新的源码,需要自己构建。
git clone https://github.com/vuejs/vue.git node_modules/vue
cd node_module/vue
npm install
npm run build
5.Bower
Bower只提供UMD版本
# 最新稳定版本
$ bower install vue
6.AMD模块加载器
所有UMD版本都可以直接使用AMD模块。
Vue相关知识点记录的更多相关文章
- 【记录】vue相关知识点
let let是es6新引入的命令,与var命令类似,但是let是声明的局部变量,只在所在代码块中有效. ES5 只有全局作用域和函数作用域,没有块级作用域,这带来很多不合理的场景. var s = ...
- vue相关知识点及面试
### vue #### vue生命周期 beforeCreated `实例初始化,数据观察和event/watch事件配置之前被调用` created `实例创建后立即调用,数据观测,数据和方法运算 ...
- vue相关知识点
1.el-date-picker输入的时间范围需要两点 A.禁用键盘输入 :editable=false,否则虽然禁用,但是输入框还能输入 B.指定时间范围::picker-options=" ...
- 2016年gift上线相关知识点记录
1.图片初始化加载 2.如何判断横屏 function horAver() { if (window.orientation == 90 || window.orientation == -90) { ...
- 学习记录013-NFS相关知识点
一.NFS相关知识点 1.NFS常用的路径/etc/exports NFS服务主配置文件,配置NFS具体共享服务的地点/usr/sbin/exportfs NFS服务的管理命令,exportfs -a ...
- Vue基础01vue的基本示例,vue的双向数据绑定,vue中常见的几种用法,vue相关常见指令
自学vue框架,每天记录重要的知识点,与大家分享!有不足之处,希望大家指正. 本篇将讲述:vue的基本示例,vue的双向数据绑定,vue中常见的几种用法,vue相关常见指令 前期学习基础,使用vue. ...
- C#知识点记录
用于记录C#知识要点. 参考:CLR via C#.C#并发编程.MSDN.百度 记录方式:读每本书,先看一遍,然后第二遍的时候,写笔记. CLR:公共语言运行时(Common Language Ru ...
- spring mvc开发过程知识点记录
给一个客户做的一个小项目,需求就是输入类似一个短网址http://dd.yy/xxxx然后跳转到另外一个域名下的图书文件.(实际很多短网址站都提供API供调用吧,不过客户需求是他自己建立一个短网址服务 ...
- Caffe学习系列(二)Caffe代码结构梳理,及相关知识点归纳
前言: 通过检索论文.书籍.博客,继续学习Caffe,千里之行始于足下,继续努力.将自己学到的一些东西记录下来,方便日后的整理. 正文: 1.代码结构梳理 在终端下运行如下命令,可以查看caffe代码 ...
随机推荐
- Hello,DTOS!(上)
主引导程序是软件还是固件?如果是软件,那么由谁开发?如何开发?主引导程序是软件.因为它不是固化于硬件当中的,并不是在出厂之前已经烧到硬件里面去了.因此它必然是软件.既然是软件,那是谁来开发它呢?就目前 ...
- 【java】字符串截取
String a = 'abcdef';String a = a.substring(0,1); a = 'a'; substring(int beginIndex, int endIndex) be ...
- Spring Cloud微服务安全实战_3-3_API安全之流控
这几篇将API安全的 流控.认证.审计.授权 简单的过一遍,对这些概念先有个初步印象.后边还会详细讲解. 本篇说API安全之流控~第一印象. 一.概念 流控,流量控制,只放系统能处理的请求的数量过去, ...
- Codeforces Round #603 (Div. 2) E - Editor(线段树,括号序列)
- plv8 rpm包创建
以下是从一个三方rpm构建,获取到的rpm 包制作spec,主要是学习下pg 扩展rpm 包的打包 rpm src 包 下载地址 https://fedora.pkgs.org/29/fedora-x ...
- ESP8266 LUA脚本语言开发: 准备工作-官网获取LUA固件
前言 这节咱去官网上获取lua开发的固件. 官网下载 下面是我以前写的,咱不使用官网下载的固件,咱使用自己编译的固件.. 填写好自己的的邮箱地址,然后选择好自己需要的功能,一会编译好的固件就会发到您的 ...
- springboot事务
参考: 1.https://www.cnblogs.com/kesimin/p/9546225.html https://www.cnblogs.com/east7/p/10585724.html
- Computer-Hunters——项目系统设计与数据库设计
Computer-Hunters--项目系统设计与数据库设计 前言 本次作业属于2019秋福大软件工程实践Z班 本次作业要求 团队名称: Computer-Hunters 本次作业目标:撰写一份针对团 ...
- 【Gamma】项目展示
团队成员介绍 大娃 :后端开发人员,主要工作为后端开发,文档撰写. 大娃的个人博客 二娃 PM,主要工作为项目进度把控,例会博客撰写. 二娃的个人博客 三娃* PM,主要工作为项目进度把控,用户需求分 ...
- python数据分析5 数据转换
1数据转换 数据转换时数据准备的重要环节,它通过数据平滑,数据聚集,数据概化,规范化等凡是将数据转换成适用于数据挖掘的形式 1.1 数据平滑 去除数据中的噪声,将连续数据离散化.这里可以采用分箱.聚类 ...