一、vscode

1、下载地址

https://code.visualstudio.com/

2、安装插件

Vscode的emmet插件 vscode emmet插件安装_Vscode的emmet插件


live server:内置服务器可以模拟访问,不用tomcat了

vetur、vue-helper:vue相关插件

3、相关设置

设置字体大小:
左边栏 管理-> 设置-> 搜索 “font” -> Font size

开启完整的Emmet语法支持:

设置中搜索 Emmet:启用如下选项,必要时重启vs

Vscode的emmet插件 vscode emmet插件安装_html_02

创建项目:
vscode本身没有新建项目的选项,所以要先创建一个空的文件夹,
然后打开vscode,再在vscode里面选择 文件 -> Open Folder 打开文件夹,这样才可以创建项目。

保存工作区:

打开文件夹后,选择“文件 -> 将工作区另存为…”,为工作区文件起一个名字,存储在刚才的文件夹下即可

Vscode的emmet插件 vscode emmet插件安装_html_03

新建文件夹和网页:

(要自己输入后缀比如.html)

Vscode的emmet插件 vscode emmet插件安装_vue.js_04


运行:

右键 open with live server,可以直接在浏览器打开

Vscode的emmet插件 vscode emmet插件安装_html_05


也可以ip地址+端口号(默认5500)

二、ECMAScript6

1、简介

ECMAScript 6.0(简称 ES6)是 JavaScript 语言的下一代标准, 2015 年 6 月正式发布。它的目标,是使得 JavaScript 语言可以用来编写复杂的大型应用程序,成为企业级开发语言。

ECMAScript 和 JavaScript 的关系是,前者是后者的规格,后者是前者的一种实现(另外的 ECMAScript 方言还有 Jscript 和 ActionScript)

2、语法

浏览器-开发者工具-控制台,可以查看调试信息

直接打!可以出来一堆模板信息

再打script标签可以在里面写代码

Vscode的emmet插件 vscode emmet插件安装_Vue_06

2.1 var/let变量

// var 声明的变量没有局部作用域
// let 声明的变量  有局部作用域
{
    var a = 1;
    let b = 2;
}
console.log(a)
console.log(b)  //b is not defined
// var 可以声明多次
// let 只能声明一次
var m = 1;
var m = 2;
let n = 10;
let n = 20;  //'n' has already been declared
console.log(m)
console.log(n)

2.2 const常量

// 1、声明之后不允许改变    
const PI = "3.1415926"
PI = 3     // TypeError: Assignment to constant variable.

// 2、一但声明必须初始化,否则会报错
const MY_AGE  // Missing initializer in const declaration

2.3 解构赋值

//1、数组解构
let a = 1, b = 2, c = 3
//console.log(a, b, c)
// ES6
let [x, y, z] = [1, 2, 3]
//console.log(x, y, z)

//2、对象解构
let user = {name: 'Helen', age: 18}
// 传统
let name1 = user.name
let age1 = user.age
console.log(name1, age1)
// ES6
let { name, age } =  user  //注意:结构的变量必须是user中的属性
console.log(name, age)

2.4 模板字符串

模板字符串相当于加强版的字符串,用反引号 `,除了作为普通字符串,还可以用来定义多行字符串,还可以在字符串中加入变量和表达式。

//字符串插入变量和表达式
//变量名写在 ${} 中,${} 中可以放入 JavaScript 表达式。
let name = "lucy"
let age = 20
let info = `My name is ${name} ,I am ${age+1}`
console.log(info)

2.5声明对象简写

//传统方式定义对象
const name = "lucy"
const age = 20
const user1 = {name:name,age:age}
//console.log(user1)
//es6
const user2 = {name,age}
console.log(user2)

2.6对象拓展运算符

拓展运算符(…)用于取出参数对象所有可遍历属性然后拷贝到当前对象。

//对象复制
let person1 = {name: "Amy", age: 15}
let someone1 = { ...person1}
//console.log(someone1)

//对象合并
let age = {age: 15}
let name = {name: "Amy"}
let person2 = {...age, ...name}
console.log(person2)

2.7箭头函数

箭头函数提供了一种更加简洁的函数书写方式。基本语法是:
参数 => 函数体
箭头函数多用于匿名函数的定义

//传统方式定义函数
var f1 = function(a) {
    return a
}
//console.log(f1(3))

//es6使用箭头函数定义
//参数 => 函数体
var f2 = a => a
//console.log(f2(4))

使用箭头函数

// 当箭头函数没有参数或者有多个参数,要用 () 括起来。
// 当箭头函数函数体有多行语句,用 {} 包裹起来,表示代码块,
// 当只有一行语句,并且需要返回结果时,可以省略 {} , 结果会自动返回。
var f3 = function(m,n) {
    return m+n
}

//es6 
var f4 = (m,n) => m+n
console.log(f4(4,5))

三、vue

Vue.js 是一款流行的 JavaScript 前端框架,目的是简化 Web 开发。Vue 所关注的核心是 MVC 模式中的视图层,同时,它也能方便地获取数据更新,实现视图与模型的交互。
官方网站:https://cn.vuejs.org

1、入门

1)创建vue文件夹,创建test.html,将vue.js或vue.min.js放在vue文件夹下
2)在body中引入vue

<script src="vue.js"></script>

3)显示

<body>
    <script src="vue.js"></script>
    
    <div id="app">
        <!-- 插值表达式,绑定vue中的data数据-->
        {{message}}
    </div>

    <script>
        new Vue({
            el:'#app',//绑定vue作用的范围
            data: {//定义页面中显示的内容
                message:'hello vue'
            }
        })
    </script>
    
</body>

2、创建自定义代码片段

文件 => 首选项 => 用户片段 => 新建全局代码片段文件
命名:vue-html.code-snippets(后缀固定),保存

{
	"vue htm": {
		"scope": "html",
		"prefix": "vuehtml",
		"body": [
			"<!DOCTYPE html>",
			"<html lang=\"en\">",
			"",
			"<head>",
			"    <meta charset=\"UTF-8\">",
			"    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">",
			"    <meta http-equiv=\"X-UA-Compatible\" content=\"ie=edge\">",
			"    <title>Document</title>",
			"</head>",
			"",
			"<body>",
			"    <div id=\"app\">",
			"",
			"    </div>",
			"    <script src=\"vue.min.js\"></script>",
			"    <script>",
			"        new Vue({",
			"            el: '#app',",
			"            data: {",
			"                $1",
			"            }",
			"        })",
			"    </script>",
			"</body>",
			"",
			"</html>",
		],
		"description": "my vue template in html"
	}

}

以后在html文件中打“vuehtml”(prefix里的内容)就会出现自定义的模板代码片

3、基本语法

3.1、单项绑定

显示红色的“单项绑定”
普通:

<body>
    <div id="app">
        <div style="color: red;">单向绑定</div>

    </div>

单项绑定:
插值法{{}}太麻烦了,可以直接 v-bind:前缀,直接写:也可以

<body>
    <div id="app">
        <div v-bind:style="msg">单向绑定</div>

    </div>
    <script src="vue.js"></script>
    <script>
        new Vue({
            el: '#app',
            data: {
                msg:'color:green;'
            }
        })
    </script>
</body>

3.2、双项绑定

<body>
    <div id="app">
    
    <!-- 插值 -->
    {{keyword}}
    <!-- 单向绑定 -->
    <br/>
    <Input type="text":value="keyword"/>
    <!-- 双向绑定 -->
    <br/>
    <Input type="text" v-model="keyword"/>

    </div>
    <script src="vue.js"></script>
    <script>
        new Vue({
            el: '#app',
            data: {
                keyword:'尚硅谷'
            }
        })
    </script>
</body>

Vscode的emmet插件 vscode emmet插件安装_html_07

在单向绑定输入框里变动,只有自己一行变;
在双向绑定输入框里变动,三行全都变;

3.3、事件

v-on: 或 @
点击的时候控制台输出show

<body>
    <div id="app">
    
        <button v-on:click="show()">事件绑定1</button>
        <button @click="show()">事件绑定2</button>
    

    </div>
    <script src="vue.js"></script>
    <script>
        new Vue({
            el: '#app',
            methods:{
                show(){
                    console.log("show")
                }
            }
        })
    </script>
</body>

3.4、条件渲染

v-if v-else

<body>
    <div id="app">
    
        <input type="checkbox" v-model="ok"/>
        <br/>
        <div v-if="ok">选中了</div>
        <div v-else>没有选中</div>
    

    </div>
    <script src="vue.js"></script>
    <script>
        new Vue({
            el: '#app',
            data: {
                ok:false
            }

        })
    </script>
</body>

Vscode的emmet插件 vscode emmet插件安装_html_08


Vscode的emmet插件 vscode emmet插件安装_Vscode的emmet插件_09

3.5、列表渲染(循环指令)

v-for

<body>
    <div id="app">
    
        <div v-for="user in userList"> {{user.name}} -- {{user.age}} </div>
        <div v-for="(user,index) in userList">
        		{{index}} -- {{user.name}} -- {{user.age}}</div>

    </div>
    <script src="vue.js"></script>
    <script>
        new Vue({
            el: '#app',
            data: {
                userList:[ {"name":"lucy","age":20},{"name":"mary","age":30}]
            }
        })
    </script>
</body>

Vscode的emmet插件 vscode emmet插件安装_html_10

3.6、实例生命周期

created() 在页面渲染之前执行
mounted() 在页面渲染之后执行

<body>
    <div id="app">
    
        {{msg}}

    </div>
    <script src="vue.js"></script>
    <script>
        new Vue({
            el: '#app',
            data: {
                msg:"hello"
            },
            created() { //在页面渲染之前执行
            debugger//断点
            console.log('created.....')
            },
            mounted() {//在页面渲染之后执行
            debugger
            console.log('mounted.....')
            }

        })
    </script>
</body>

4、axios

axios是独立于vue的一个项目,可以用于浏览器和node.js中发送ajax请求

将vue.min.js和axios.min.js引入文件夹

<script src="vue.js"></script>
<script src="axios.min.js"></script>

新建一个user.js文件

{
    "code":200,
    "message":"成功",
    "data":{
        "items":[
            {"name":"lucy","age":20},
            {"name":"aa","age":21},
            {"name":"bb","age":22}
        ]
    }
}

编写代码将user.json显示出来

<body>
    <div id="app">
        <table>
            <tr v-for="user in userList">
                <td>{{user.name}}</td>
                <td>{{user.age}}</td>
            </tr>
        </table>        
    </div>
    <script src="vue.js"></script>
    <script src="axios.min.js"></script>
    
    <script>
        new Vue({
            el: '#app',
            data: {
                userList:[]
            },
            created(){//页面渲染前执行,调用方法返回json数据
                this.getList()
            },
            methods:{
                getList(){//使用axios方式ajax请求
                    axios.get("user.json")//请求的数据路径
                        .then(response=>{//请求成功
                            //console.log(response)
                            this.userList=response.data.data.items
                            console.log(this.userList)
                        })
                        .catch(error=>{//请求失败
                            console.log(error)
                        })
                }
            }            
        })
    </script>
</body>

then里的response:

Vscode的emmet插件 vscode emmet插件安装_html_11

5、element-ui

element-ui 是饿了么前端出品的基于 Vue.js的 后台组件库,方便程序员进行页面快速布局和构建,需要什么组件直接复制过来用就行

官网: http://element-cn.eleme.io/#/zh-CN

六、Node.js

1、简介

主要两个作用:

①JavaScript运行环境
Node.js内置了Chrome的V8 引擎,脱离浏览器环境也可以运行JavaScript,只要有JavaScript引擎就可以。

与Chrome浏览器中写JavaScript不同之处:

  • Node.js没有浏览器API,即document,window的等。
  • 加了许多Node.js 专属API,例如文件系统,进程,http功能。

②模拟服务端效果
通常他会被用来作一个BFF层,即 Backend For Frontend(服务于前端的后端),通俗的说是一个专门用于为前端业务提供数据的后端程序

服务端的将数据按照不同终端的不同要求进行裁剪,或者接口整合,发给浏览器,这个服务层叫做BFF。

Vscode的emmet插件 vscode emmet插件安装_html_12


Vscode的emmet插件 vscode emmet插件安装_html_13

2、安装

官网:https://nodejs.org/en/
中文网:http://nodejs.cn/
LTS:长期支持版本
Current:最新版

查看版本cmd:
Node -v

3、简单使用

vscode里新建test.js文件

console.log('hello nodejs')

!!!要记得保存!!!

法一:cmd进入test.js所在目录,node test.js

简单方法:直接在文件夹里选中,然后打cmd回车

Vscode的emmet插件 vscode emmet插件安装_Vscode的emmet插件_14


Vscode的emmet插件 vscode emmet插件安装_Vscode的emmet插件_15


法二:

Vscode的emmet插件 vscode emmet插件安装_vue.js_16


就和cmd页面一样

Vscode的emmet插件 vscode emmet插件安装_Vue_17


报错无法识别node的话需要以管理员方式启动vscode,右键vscode–>属性–>兼容性

Vscode的emmet插件 vscode emmet插件安装_html_18

4、模拟服务器

使用8888端口:

//引入http模块
const http = require('http');
//创建服务器
http.createServer(function (request, response) {
// 发送 HTTP 头部 
// HTTP 状态值: 200 : OK
// 内容类型: text/plain
response.writeHead(200, {'Content-Type': 'text/html'});
// 发送响应数据 "Hello World"
response.end('<h1>Hello Node.js Server</h1>');
}).listen(8888);
// 终端打印如下信息
console.log('Server running at http://127.0.0.1:8888/');

运行后,使用浏览器访问http://127.0.0.1:8888/

Vscode的emmet插件 vscode emmet插件安装_Vue_19