【尚硅谷《谷粒商城》2020学习笔记】三、前端基础
前后端技术栈类比
前端 | 后端 | |
---|---|---|
编程语言 | JavaScript | Java |
版本 | ES6、7、8 | JDK8、9、10、11 |
框架 | JQuery、Vue、React | Spring、SpringMVC |
工具 | WebStorm、VsCode | IDEA、Eclipse |
项目构建 | webpack、gulp | maven、gradle |
依赖管理 | npm | maven |
ES6
参考文档:http://caibaojian.com/es6/
一、简介
ECMAScript 6.0(以下简称ES6)是JavaScript语言的下一代标准,已经在2015年6月正式发布了。它的目标,是使得JavaScript语言可以用来编写复杂的大型应用程序,成为企业级开发语言。
ECMAScript和JavaScript的关系
一个常见的问题是,ECMAScript和JavaScript到底是什么关系?
要讲清楚这个问题,需要回顾历史。1996年11月,JavaScript的创造者Netscape公司,决定将JavaScript提交给国际标准化组织ECMA,希望这种语言能够成为国际标准。次年,ECMA发布262号标准文件(ECMA-262)的第一版,规定了浏览器脚本语言的标准,并将这种语言称为ECMAScript,这个版本就是1.0版。
该标准从一开始就是针对JavaScript语言制定的,但是之所以不叫JavaScript,有两个原因。一是商标,Java是Sun公司的商标,根据授权协议,只有Netscape公司可以合法地使用JavaScript这个名字,且JavaScript本身也已经被Netscape公司注册为商标。二是想体现这门语言的制定者是ECMA,不是Netscape,这样有利于保证这门语言的开放性和中立性。
因此,ECMAScript和JavaScript的关系是,前者是后者的规格,后者是前者的一种实现(另外的ECMAScript方言还有Jscript和ActionScript)。日常场合,这两个词是可以互换的。
二、let & const
1. 作用域
示例:
1 | <script> |
运行结果:
2. 重复声明
1 | <script> |
3. 不存在变量提升
1 | <script> |
4. const
const
声明一个只读的常量。一旦声明,常量的值就不能改变。
1 | const PI = 3.1415; |
三、解构 & 字符串
1. 解构
ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring)。
数组解构:
1 | let a = 1; |
对象解构:
1 | let person = { |
2. 字符串
字符串拓展:
1 | var s = 'Hello world!'; |
模板字符串:
1 | //传统的输出模板 |
四、函数优化
1. 函数参数默认值
1 | function add(a, b = 1) { |
2. 不定参数
1 | function fun(...values) { |
3. 箭头函数
1 | // let print = function(obj) { |
五、对象优化
1. Object 的方法
1 | const person = { |
2. 声明对象简写
1 | let name = "wxs"; |
3. 对象函数的属性简写
1 | let person = { |
4. 对象的拓展运算
1 | //对象拓展运算 |
六、map & reduce
七、Promise
八、模块化
1. 简介
模块化就是把代码进行拆分,方便复用,类似于 Java 中的导包。
2. 使用
export
import
Vue
参考文档:http://caibaojian.com/vue/guide/
一、概念
Vue.js(读音 /vjuː/, 类似于 view) 是一套构建用户界面的 渐进式框架。与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计。Vue 的核心库只关注视图层,并且非常容易学习,非常容易与其它库或已有项目整合。另一方面,Vue 完全有能力驱动采用单文件组件和 Vue 生态系统支持的库开发的复杂单页应用。
Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。
二、快速开始
在 VsCode 中打开新的文件夹
控制台执行以下命令
cnpm init -y
cnpm install vue
至此,vue项目构建完成
新建测试文件:index.html
引入 Vue
编写测试代码
完整代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<div id="app">
<h1>{{name}},帅的一</h1>
</div>
<script src="./node_modules/vue/dist/vue.js"></script>
<script>
let vm = new Vue({
el: "#app",
data: {
name: "wxs"
}
});
</script>
</body>
</html>显示效果:
![image-20200602092626792](【尚硅谷《谷粒商城》2020学习笔记】三、前端基础/image-20200602092626792.png
三、常用指令
官方文档都有,就不一一赘述
(其实就是懒hhh)