为什么要学 ES6 的语法呢?

因为 Vue 语法有很多都是 ES6(ECMAScript 6),这里推荐 [阮一峰 ECMAScript 6 入门]: http://es6.ruanyifeng.com/

# // var 声明的是全局变量
<script type="text/javascript">
// 输出a,发现没有,会自动在前面 var a; 然后再进行操作
console.log(a) //有变量提升,undefined
{
var a = 3;
}
console.log(a) //3 # let 声明的是局部的,不会存在变量提升
console.log(b)
{
// b 是局部作用域的 只能在这个大括号里才能使用
let b = 10;
}
console.log(b)
</script> let声明变量的特点:
1、局部作用域
2、不会存在变量提升
3、变量不能重复声明 let 与 var 声明变量的区别:
var 声明的是全局变量,而 let 是局部的

const 声明变量

	<script>
console.log(b)
{
const b = 10;
b = 20; // 报错
}
console.log(b)
</script> const 声明变量的特点:
1、局部作用域
2、不会存在变量提升
3、变量不能重复声明
4、只能声明常量,不可变的量 (比 let 声明变量多一个特点)

模板字符串

tab 键上面的反引号 `${变量名}` 来插值

<script>
let name = '未来';
let str = `我是${name}`; console.log(str) // 我是未来
</script>

ES6 的箭头函数

funtion () {} === () => {}  this的指向发生改变

# ES5 声明函数:
function add(x){
return x;
}
add(5) let add = function(x){
return x;
}
console.log(add(50)) # ES6 声明函数(箭头函数):
let add = (x) => {
return x;
}
console.log(60) # 简洁版(不易阅读):
let add2 = x => x;
console.log(add2(100)) #ES5 的案例:
<script type="text/javascript">
let person = {
name: '日天',
age: 18,
fav: function(){
console.log(this) // 指向 person
console.log(this.name) // 日天
}
}
person.fav()
</script> # ES6 的案例:
let person = {
name: '日天',
age: 30,
fav: () => {
//this指向 发生了改变。this指向 定义person的父级对象(上下文)
console.log(this) // 指向window
console.log(this.name) // 输出 空
}
}
person.fav() # 对象的单体模式
<script type="text/javascript">
let person = {
name: '日天',
age: 18,
fav(){ // 相当于 fav:function(){}函数声明
console.log(this) // // 指向 person
console.log(this.name) // 输出 日天
}
}
person.fav()
</script>

ES6 的类

function person(name, age){
this.name = name;
this.age = age;
}
var p1 = person('tom','16'); <script>
//声明一个Person 类
class Person{
// 当前类的父类(继承性)
// constructor 方法相当于python中的__init__初始化方法
constructor(name='tom', age=45){
this.name = name;
this.age = age;
}
showname(){
console.log(this.name)
}
showage(){
console.log(this.age)
}
} let v = new Person();
v.showname(); //输出tom
</script>

Vue小白篇 - ES6的语法的更多相关文章

  1. Vue小白篇 -Vue 的模板语法

    可以插入任何你想插入的内容,除了 if-else if-else用三元运算符代替 <div id="box"> <!--模板语法--> <h2> ...

  2. 面向对象编程-终结篇 es6新增语法

    各位,各位,终于把js完成了一个段落了,这次的章节一过我还没确定下面要学的内容可能是vue也可能是前后端交互,但无论是哪个都挺兴奋的,因为面临着终于可以做点看得过去的大点的案例项目了,先憋住激动地情绪 ...

  3. Vue小白篇 - Vue介绍

    Vue ?啥是Vue?能干嘛? vue 的介绍 Vue 是一套用于构建用户界面的 渐进式框架 ,与其它大型框架不同的是, Vue 被设计为可以自底向上逐层应用.Vue 的核心库只关注视图层 前端三大框 ...

  4. Vue小白篇 - Vue 的指令系统 (1) v-text、v-html

    v-text:相当于innerText v-html:相当于innerHTML <div id="box"> {{ msg }} <div v-text=&quo ...

  5. Webstorm添加新建.vue文件功能并支持高亮vue语法和es6语法

    转载:https://blog.csdn.net/qq_33008701/article/details/56486893 Webstorm 添加新建.vue文件功能并支持高亮vue语法和es6语法 ...

  6. Vue(1)- es6的语法、vue的基本语法、vue应用示例,vue基础语法

    一.es6的语法 1.let与var的区别 ES6 新增了let命令,用来声明变量.它的用法类似于var(ES5),但是所声明的变量,只在let命令所在的代码块内有效.如下代码: { let a = ...

  7. webstorm中.vue报错(es6语法报错)-转

    1.webstorm中es6语法报错,解决方法: 打开 Settings => Languages & Frameworks => Javascript把 Javascript L ...

  8. es6基本语法,vue基本语法

    一.es6基本语法 0.es6参考网站 http://es6.ruanyifeng.com/#README 1.let 和 const (1)const特点: 只在局部作用域起作用 不存在变量提升 不 ...

  9. 小白学习VUE第一篇文章---如何看懂网上搜索到的VUE代码或文章---使用VUE的三种模式:

    小白学习VUE第一篇文章---如何看懂网上搜索到的VUE代码或文章---使用VUE的三种模式: 直接引用VUE; 将vue.js下载到本地后本目录下使用; 安装Node环境下使用; ant-desig ...

随机推荐

  1. MySQL--07 explain用法

    目录 MySQL explain用法 一.explain命令应用 二. Extra(扩展) 三.建立索引的原则(规范) 总结: MySQL explain用法 一.explain命令应用 查询数据的方 ...

  2. kali Linux 入门(一)

    一.描述 1.基于Debian Linux 发行版 2013年3月13日 2.包含约600个安全工具 3.定制 安全稳定的内核 4.前身是BackTrack(2013年停止维护) 5.官方机构:Off ...

  3. Web核心之Request对象

    HTTP协议中Request请求部分格式 //请求行(这种是POST类型的请求) POST /HttpServleLogin.html HTTP/1.1 //请求头(User-Agent里有Firef ...

  4. Vue.js----更换头像不实时更新问题

    原因 导致问题的原因是缓存造成的,因为你图片变了但是读取头像的地址还会没有变化的 解决思路 所以解决的思路就是上传之后让图片地址改变,那么我们就可以在上传的时候给地址加上一个时间戳那么久可一达到目的了 ...

  5. 【leetcode】905. Sort Array By Parity

    题目如下: 解题思路:本题和[leetcode]75. Sort Colors类似,但是没有要求在输入数组本身修改,所以难度降低了.引入一个新的数组,然后遍历输入数组,如果数组元素是是偶数,插入到新数 ...

  6. 每天一个linux命令:less(14)

    less less命令的作用与more十分相似,都可以用来浏览文字档案的内容,less 在查看之前不会加载整个文件 .用less命令显示文件时,用PageUp键向上翻页,用PageDown键向下翻页. ...

  7. ES6中类Class的super关键字

    super 关键字,既可以当作函数使用,也可以当作对象使用.在这两种情况下,它的用法完全不同. 1.super当做函数使用 super 作为函数调用时,代表父类的构造函数.ES6 要求,子类的构造函数 ...

  8. 数字电路的与门、或门、非门--FPGA--005

    作者:young cc 链接:https://www.zhihu.com/question/23829080/answer/123791730来源:知乎著作权归作者所有,转载请联系作者获得授权. 数字 ...

  9. 【HDOJ6611】K Subsequence(费用流)

    题意:给定一个长为n的正整数序列,要求从中取出至多k个不下降序列,使得它们的和最大,求这个和 n<=2e3,k<=10,a[i]<=1e5 思路:极其考验模板,反正我的spfa和zk ...

  10. C#_winform登陆框验证码的实现

    验证码技术已愈来愈成熟,从最初的数字.字母.字符.汉字已经到目前的语言,其应用也甚广,之前大多数只有在网站上可以看到,现在在一些客户端软件也经常可见(比如证券相关软件).之前做的一个基于 C# 客户端 ...