06_Node.js服务器开发

1 服务器开发的基本概念

1.1 为什么学习服务器开发

Node.js开发属于服务器开发,那么作为一名前端工程师为什么需要学习服务器开发呢?

为什么学习服务器开发?

  • 能够和后端程序员更加紧密配合
  • 网站业务逻辑前置
  • 扩宽知识视野

1.2 服务器开发可以做哪些事情

  • 实现网站的业务逻辑
  • 实现数据的增删改查

1.3 Node.js开发服务器的优势?

  • Node.js是前端开发人员转向后端开发人员的极佳途径
  • 一些公司要求前端工程师掌握Node.js开发
  • Node.js生态系统活跃,有大量开源库可以使用
  • 前端开发工具大多基于Node.js开发

1.4 网站应用程序的组成

一个完整的网站应用程序主要由客户端服务器端两大部分组成。

我们可以将服务器理解为一台计算机,主要负责存储数据和处理应用逻辑。

用Node.js来代替传统的服务端语言(如Java语言等),开发服务端的网站应用。客户端和服务器端网站开发流程:
image.png

2 Node.js网站服务器

2.1 初识Node.js网站服务器

Node.js网站服务器必须满足以下3个条件

  • 网站服务器必须是一台计算机;
  • 计算机上需要安装Node.js运行环境;
  • 使用Node.js创建一个能够接收请求和响应请求的对象。

网站服务器开发中涉及的一些基础知识

  • IP地址
    • IP地址是互联网中设备的唯一标识,代表互联网协议地址。在计算机中,地址是由一串数字组成。
  • 域名
    • 域名平时上网所使用的网址。IP地址与域名是对应的关系,在浏览器的地址栏中输入域名,会有专门的服务器将域名解析为对应的IP地址,从而找到对应的服务器。
  • 端口
    • Node.js开发者习惯使用3000作为Node.js服务器的端口,一般来说,不使用0到1024之间的数字,因为这是操作系统软件,以及常用软件占用的端口。
  • URL
    • URL又叫统一资源定位符,它是专为标识Internet网上资源位置而设的一种编址方式。

在开发阶段,客户端和服务器端使用同一台计算机,即开发人员计算机。

这是因为在开发人员计算机中既安装了浏览器(客户端),又安装了Node.js(服务器端)。既然是同一台计算机,我们如何通过网络的方式访问它呢?

每台计算机中都有一组特殊的IP和域名,代表本机。如果将本机作为服务器,则该计算机的特定IP为127.0.0.1,特定域名为localhost。

例如在开发程序中,我们输入localhost就代表要通过网络的方式找到自己计算机当中的服务器。

2.2 创建Node.js网站服务器

在Node.js中创建网站服务器,并实现客户端向服务器端发送请求,服务器端向客户端做出响应。

// 新建app.js文件
// 在test目录下,新建app.js文件并编写如下代码
// 引用系统模块
const http = require('http');
const app = http.createServer() 	// 创建Web服务器;
// 当客户端发送请求的时候
app.on('request', (req, res) => {res.end('<h1>hi, user</h1>'); 	// 响应
});
app.listen(3000); 		// 监听3000端口
console.log('服务器已启动,监听3000端口,请访问localhost:3000');// 打开命令行工具,切换到test目录下,并输入“nodemon app.js”命令。
// 在浏览器中输入localhost:3000网址进行访问。

3 HTTP协议

3.1 请求消息

请求方式用来规定客户端与服务器端联系的类型。HTTP协议中常用的请求方式有哪些?

主要是GET和POST两种。

  • 当用户在浏览器地址栏中直接输入某个URL地址或者单击网页上一个超链接时,浏览器将默认使用GET方式发送请求。
  • 如果将网页上的标签的method属性设置为post,那么就会以POST方式发送请求。
// app.js文件中找到res.end()方法,并在res.end()方法前面编写如下代码。
// 获取请求方式
console.log(req.method);

在服务器收到GET请求和POST请求后,如何分开处理呢?

// 在app.on()中编写处理请求的代码
app.on('request', (req, res) => {// 获取请求方式console.log(req.method);if (req.method == 'POST') {res.end('post');} else if (req.method == 'GET') {res.end('get');};// 响应// res.end('<hl>hi, user</hl>');
});

在实际应用中,经常通过单击不同的链接进入不同的页面。

例如,在某个网站上,通过地址栏输入不同的网址,会跳转到相应的页面。这样的需求常常需要在服务器端进行请求处理。

Node.js中如何根据不同的URL 发送不同的响应内容?

// 创建 test 目录,在该目录下新建server.js文件
const http = require('http');
const app = http.createServer();
app.on('request', (req, res) => {var url = req.url;if (url == '/index' || url == '/') {res.end('welcome to homepage');} else if (url == '/list') {res.end('welcome to listpage');} else {res.end('not found');};
});
app.listen(3000);
console.log('服务器已启动,监听3000端口,请访问localhost:3000');// 打开命令行工具,切换到server.js文件所在目录,执行“node server.js”命令启动服务器。

3.2 响应消息

在响应消息中,对于客户端的每一次请求,服务器端都有给予响应,在响应的时候我们可以通过状态码告诉客户端此次请求是成功还是失败。

状态代码由3位数字组成,表示请求是否被理解或被满足。HTTP响应状态码的第一个数字定义了响应的类别,后面两位没有具体的分类,第1位数字有5种可能的取值。

  • 1**:请求已接收,需要继续处理。
  • 2**:请求已成功被服务器接收、理解并接受。
  • 3**:为完成请求,客户端需进一步细化请求。
  • 4**:客户端的请求有错误。
  • 5**:服务器端出现错误。

HTTP协议常见的状态码

状态码说明
200表示服务器成功处理了客户端的请求
302表示请求的资源临时从不同的URI响应请求,但请求者应继续使用原有位置来进行以后的请求
404表示服务器找不到请求的资源
400表示客户端请求有语法错误
500表示服务器发生错误,无法处理客户端的请求

响应内容类型

服务器端返回结果给客户端时,通常需要指定内容类型(content-type属性)

  • text/plain:返回纯文本格式
  • text/html:返回HTML格式。
  • text/css:返回CSS格式。
  • application/javascript:返回JavaScript格式。
  • image/jpeg:返回JPEG图片格式。
  • application/json:返回JSON代码格式。
// 创建test目录,在该目录下新建server.js文件。
// 引用系统模块
const http = require('http');
// 创建web服务器
const app = http.createServer();
// 当客户端发送请求的时候
app.on('request', (req, res) => {res.writeHead(200, {'content-type': 'text/plain'});// 响应res.end('<h1>hi, user</h1>');
});
// 监听3000端口
app.listen(3000);
console.log('服务器已启动,监听3000端口,请访问localhost:3000');// 将<h1></h1>中的英文内容改为中文“欢迎”,再次刷新页面。
// 此时标签可以正确显示,但是中文会乱码。// 修改文件中的“content-type”项
res.writeHead(200, {'content-type': 'text/html;charset=utf8'
});

4 HTTP请求与响应处理

4.1 GET请求参数

GET参数被放置在浏览器地址栏中进行传输。

// http://localhost:3000/index?name=zhangsan&age=20
// 请求参数 name=zhangsan&age=20
// 在test目录下,新建server.js作为服务器文件。
const http = require('http');	// 引用HTTP系统模块
const app = http.createServer();	// 创建网站服务器
var url = require('url');		// 引用处理URL地址模块app.on('request', (req, res) => {console.log(req.url);		// 获取整个URL中的资源具体地址console.log(url.parse(req.url, true));	// 解析URL参数let { query, pathname } = url.parse(req.url, true);if (pathname == '/index' || pathname == '/') {res.end('<h1>welcome to homepage<h1>');} else if (pathname == '/list') {res.end('welcome to listpage');} else {res.end('not found');};
});app.listen(3000);
console.log('服务器已启动,监听3000端口,请访问localhost:3000');// 回到命令行工具,切换到test目录
// 输入“nodemon server.js”命令启动服务器。

4.2 POST请求参数

POST请求参数被放置在请求体中进行传输。

<!-- 在test目录下,新建form.html文件。-->
<form method="post" action="http://localhost:3000"><input type="text" name="username"><input type="password" name="password"><input type="submit" name="">
</form>
// 在test目录下,新建post.js文件。
const http = require('http');
const app = http.createServer();
// 导入系统模块querystring用于将POST请求参数转换为对象格式
const querystring = require('querystring');
app.on('request', (req, res) => {let postParams = '';req.on('data', params => {// 监听参数传输事件postParams += params;});req.on('end', () => {// 监听参数传输完毕事件console.log(postParams);console.log(querystring.parse(postParams));});res.end('ok');
});
app.listen(3000);
console.log('服务器已启动,监听3000端口,请访问localhost:3000');// 回到命令行工具,切换到test目录,输入“nodemon post.js”命令启动服务器

4.3 路由

用户在浏览器地址栏中输入不同的请求地址,服务器端会为客户端响应不同的内容。

例如,客户端访问“http://localhost:3000/index”这个请求地址,服务器端要为客户端响应首页的内容,这是由网站应用中的路由实现的。

路由是指客户端请求地址与服务器端程序代码的对应关系。

// 在test目录下,新建app.js文件。
const http = require('http');		          // 引用系统模块HTTP
const app = http.createServer(); 	          // 创建网站服务器
const url = require('url');
app.on('request', (req, res) => {	          // 为网站服务器对象添加请求事件const method = req.method.toLowerCase();      // 获取客户端的请求方式,const pathname = url.parse(req.url).pathname;  // 获取请求地址res.writeHead(200, { 'content-type': 'text/html;charset=utf8' });// 实现路由功能if (method == 'get') {if (pathname == '/' || pathname == '/index') {res.end('欢迎来到首页');} else if (pathname == '/list') {res.end('欢迎来到列表页');} else {res.end('您访问的页面不存在');}} else if (method == 'post') {// 请求方式为POST时的逻辑处理}
});
app.listen(3000); // 监听3000端口
console.log('服务器已启动,监听3000端口,请访问localhost:3000');// 到命令行工具,切换到test目录
// 输入“nodemon app.js”命令启动服务器

4.4 静态资源访问

静态资源服务

静态资源服务是指客户端向服务器端请求的资源,服务器端不需要处理,可以直接响应给客户端的资源。

静态资源主要包括CSSJavaScriptimage文件,以及HTML文件。

动态资源指的是相同的请求地址可以传递不同的请求参数,得到不同的响应资源,这种资源称为动态资源。

实现静态资源访问

静态资源是存放在本地的,只能自己可以访问到,其他人不能访问。

如果希望服务器端的静态资源能够被用户访问到,这就需要实现静态资源访问功能

在服务器端创建一个专门的目录,存放静态资源。

当客户端请求某个静态资源文件时,服务器端将这个静态资源响应给客户端。

// 创建test目录,在该目录下新建public目录,用于存放静态文件。
// 启动服务器,在test目录下创建app.js文件。
const http = require('http');   // 引用系统模块HTTP
const app = http.createServer();// 用户创建网站服务器
const url = require('url');     // 引用url地址模块
const path = require('path');   // 引用系统模块Path,用于读取文件前拼接路径
const fs = require('fs');       // 引用系统模块Fs,读取静态资源
const mime = require('mime');   // 引用第三方模块
// 为网站服务器对象添加请求事件
app.on('request', (req, res) => {// 处理请求// 获取用户请求路径let pathname = url.parse(req.url).pathname;// 三元表达式,表达式 ? 表达式1 : 表达式2pathname = pathname == '/' ? '/default.html' : pathname;// 将用户请求的路径转换为实际的服务器硬盘路径let realPath = path.join(__dirname, 'public' + pathname);// 利用mime模块根据路径返回资源的类型let type = mime.getType(realPath);// 读取文件fs.readFile(realPath, (error, result) => {if (error != null) {    // 如果文件读取失败// 指定返回资源的文件编码res.writeHead(404, { 'content-type': 'text/html;charset=utf8' });res.end('文件读取失败');} else {                  // 如果文件读取成功res.writeHead(200, {'content-type': type});res.end(result);};});});
// 监听3000端口
app.listen(3000);
console.log('服务器已启动,监听3000端口,请访问localhost:3000');// 打开命令行工具,切换到test目录下,输入“nodemon app.js”命令

5 Node.js异步编程

5.1 同步异步API的概念

Node.js中的一些API有的是通过返回值的方式获取API的执行结果,有的是通过函数的方式获取结果,同步和异步两种API有什么区别呢?

同步API

同步API指只有当前API执行完成后,才能继续执行下一个API。

举例:到餐馆点餐时,一个指定的服务员被分配给你服务,当你点完餐时,服务员将订单送到厨房并在厨房等待厨师制作菜肴,当厨师将菜肴烹饪完成后,服务员将菜肴送到你的面前,服务完成,此时这个服务员才能服务另外的客人。也就是说,一个服务员同时只能服务于一个客人。

异步API

异步API指当前API的执行不会阻塞后续代码的执行。

举例:到餐馆点餐时,在点餐后服务员将你的订单送到厨房,此时服务员没有在厨房等待厨师烹饪菜肴,而是去服务了其他客人,当厨师将你的菜肴烹饪好以后,服务员再将菜肴送到你的面前。也就是说,一个服务员同时可以服务多个客人。

同步API的执行方式

同步API的执行方式,代码从上到下一行一行执行,下一行的代码必须等待上一行代码执行完成以后才能执行。

console.log('before');
console.log('after');

异步API的执行方式

异步API的执行方式,代码在执行过程中某行代码需要耗时,代码的执行不会等待耗时操作完成以后再去执行下一行代码,而是不等待直接向后执行。异步代码的执行结果需要通过回调函数的方式处理。

console.log('before');
setTimeout(() => {console.log('last');
}, 2000);
console.log('after');

5.2 获取异步API的返回值

同步API可以从返回值中拿到API执行的结果,那么异步API的返回值是如何获取的呢?

// 在test目录下,新建callback.js文件。
// getMsg函数定义
function getMsg(callback) {setTimeout(function () {// 调用callbackcallback({msg: 'hello node.js'});}, 2000);
};
// getMsg函数调用
getMsg(function (data) {console.log(data); // 在回调函数中获取异步API执行的结果
});// 打开命令行工具,切换到callback.js所在目录,执行“node callback.js”命令

5.3 异步编程中回调地狱的问题

什么是回调地狱

异步API不能通过返回值的方式获取执行结果,异步API也不会阻塞后续代码的执行。

如果异步API后面代码的执行依赖当前异步API的执行结果,这就需要把代码写在回调函数中。一旦回调函数的嵌套层次过多,就会导致代码不易维护,我们将这种代码形象地称为回调地狱

回调地狱案例

依次读取A文件、B文件、C文件。

通常的做法是:使用fs.readFile()方法读取A文件,A文件读取完成之后,在读取A文件的回调函数中去读取B文件;B文件读取完成之后,在读取B文件的回调函数中去读取C文件。

// (1)test目录下,创建3个文件,分别是1.txt、2.txt、3.txt。
// 其中,1.txt文件的内容为1,2.txt文件的内容为2,3.txt文件的内容为3。
// (2)在test目录下新建callbackhell.js文件。
const fs = require('fs');
fs.readFile('./1.txt', 'utf8', (err, result1) => {console.log(result1);fs.readFile('./2.txt', 'utf8', (err, result2) => {console.log(result2);fs.readFile('./3.txt', 'utf8', (err, result3) => {console.log(result3);});});
});// 打开命令行工具,切换到callbackhell.js所在目录,执行“node callbackhell.js”命令

5.4 利用Promise解决回调地狱

利用Promise解决回调地狱

Promise本身是一个构造函数,如果要使用Promise解决回调地狱的问题,需要使用new关键字创建Promise构造函数的实例对象。

// 定义Promise
let promise = new Promise((resolve, reject) => { });
// 定义resolve和reject参数函数
promise.then(result => console.log(result)).catch(error => console.log(error));
// 在test目录下新建promise.js文件。
const fs = require('fs');
function p1() {return new Promise((resolve, reject) => {fs.readFile('./1.txt', 'utf8', (err, result) => {resolve(result);});});
}
function p2() {}
function p3() {}
p1().then((r1) => {console.log(r1);// 使用return返回p2()函数的Promise对象// 会在下一个then()中拿到这个Promise对象的结果return p2();
}).then((r2) => {// 获取上一个Promise对象的结果
}).then((r3) => {// 获取上一个Promise对象的结果console.log(r3);
})// 打开命令行工具,切换到promise.js所在目录,执行“node promise.js”命令。

5.5 异步函数

异步函数

异步函数实际上是在Promise对象的基础上进行了封装,它把一些看起来比较繁琐的代码封装起来,然后开放一些关键字供开发者来使用。

异步函数是异步编程语法的终极解决方案,它可以让我们将异步代码写成同步的形式,让代码不再有回调函数嵌套,使代码变得清晰明了。

async关键字

异步函数需要在function前面加上async关键字。

async function fn() {// throw代替reject()方法throw '发生错误';// return代替resolve()方法return 123;
}fn().then(function (data) {// 获取到return的值123console.log(data);
}).catch(function (error) {// 捕获throw的抛出错误console.log(error);
})

await关键字

await关键字可以暂停异步函数的执行,等待Promise对象返回结果再向下执行函数。

await关键字只能出现在异步函数中,await后面只能写Promise对象,不能写其他类型API。

// 使用await关键字实现3个异步函数的有序执行
// 在test目录下新建await.js文件。
async function p1() {return 'p1';}
async function p2() {return 'p2';}
async function p3() {return 'p3';}
async function run() {let r1 = await p1();let r2 = await p2();let r3 = await p3();console.log(r1);console.log(r2);console.log(r3);
}
run();// 打开命令行工具,切换到await.js所在目录,执行“node await.js”命令
// 使用异步函数优化前面编写的promise.js文件中的代码
// 在test目录下新建async.js文件。
const fs = require('fs');
const promisify = require('util').promisify;
const readFile = promisify(fs.readFile);
async function run() {let r1 = await readFile('./1.txt', 'utf8');let r2 = await readFile('./2.txt', 'utf8');let r3 = await readFile('./3.txt', 'utf8');console.log(r1);console.log(r2);console.log(r3);
}
run();// 打开命令行工具,切换到async.js所在目录,执行“node async.js”命令。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/99566.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

bochs 对 Linux0.11 进行调试 (TODO: 后面可以考虑集成 vscode+gdb+qemu)

我在阅读 Linux0.11 源码时&#xff0c;对一个指令 LDS 感到困惑。 看了下 intel 指令集手册&#xff0c;能猜到 LDS 的功能&#xff0c;但不确定。 于是决定搭建调试环境&#xff0c;看看 LDS 的功能是否真如自己猜测。 首先 make debug 运行 qemu-Linux0.11&#xff0c;命…

基于Java+SpringBoot+Vue在线家具商城系统的设计与实现 前后端分离【Java毕业设计·文档报告·代码讲解·安装调试】

&#x1f34a;作者&#xff1a;计算机编程-吉哥 &#x1f34a;简介&#xff1a;专业从事JavaWeb程序开发&#xff0c;微信小程序开发&#xff0c;定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事&#xff0c;生活就是快乐的。 &#x1f34a;心愿&#xff1a;点…

Ubuntu20.04 配置 yolov5_ros 功能包记录

文章目录 本文参考自博主源801,结合自己踩坑后修改 项目地址:https://github.com/mats-robotics/yolov5_ros 1.新建工作空间 新建一个工作空间 yolo_ros(名字可自定义),在 yolo_ros 下新建文件夹 src 并catkin_make进行编译 2. 安装相机驱动,可以选用较为主流的 usb_cam 或…

ios safari 浏览器跳转页面没有自适应

今天开发遇到了一个问题&#xff0c;当用户点击浏览器中的表单进行注册时&#xff0c;表单元素会放大&#xff0c;随后跳转页面无法还原到初始状态。 这是因为如果 的 font-size 被设定为 16px 或更大&#xff0c;那么 iOS 上的 Safari 将正常聚焦到输入表单中。但是&#xff…

2023版 STM32实战8 独立看门狗(IWDG)

IWDG简介 STM32F10xxx内置两个看门狗&#xff0c;提供了更高的安全性、时间的精确性和使用的灵活性。两个看门狗设备(独立看门狗和窗口看门狗)可用来检测和解决由软件错误引起的故障。 说人话就是能解决程序跑飞的问题。 编写代码思路 -1- 使用这个功能必须解除写保护 -2-…

FLIP动画做拖拽排序效果

先来看效果 index.html文件 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta http-equiv"X-UA-Compatible" content"IEedge" /><meta name"viewport" content&quo…

Netty深入浅出(无处不在的IO)

为什么要有Netty Netty是为了解决网络编程的复杂性和提供易于使用、高性能和可扩展的框架而开发的。它通过提供一组可重用的组件来处理网络通信的低级细节&#xff0c;例如套接字管理、线程和缓冲&#xff0c;简化了开发网络应用程序的过程。这使开发人员可以专注于应用程序逻…

自然语言处理 | WordNet

WordNet是词汇数据库,即英语词典,专为自然语言处理而设计。 Synset是一种特殊的简单接口,存在于 NLTK 中, 用于在 WordNet 中查找单词。同义词集实例是表达相同概念的同义词的分组。有些单词只有一个同义词集,有些则有多个。

C#对字典容器Dictionary<TKey, TValue>内容进行XML序列化或反序列化报错解决方法

一、问题描述 在使用C#对字典容器Dictionary<TKey, TValue>内容进行XML序列化报错【System.Exception:“不支持类型 System.Collections.Generic.Dictionary2[[System.String, mscorlib, Version2.0.0.0, Cultureneutral, PublicKeyTokenb77a5c561934e089],[System.Strin…

基于matlab统计Excel文件一列数据中每个数字出现的频次和频率

一、需求描述 如上表所示&#xff0c;在excel文件中&#xff0c;有一列数&#xff0c;统计出该列数中&#xff0c;每个数出现的次数和频率。最后&#xff0c;将统计结果输出到新的excel文件中。 二、程序讲解 第一步&#xff1a;选择excel文件&#xff1b; [Filename, Pathn…

C++笔记之信号量、互斥量与PV操作

C笔记之信号量、互斥量与PV操作 文章目录 C笔记之信号量、互斥量与PV操作1.信号量概念2.信号量例程一3.信号量例程二4.信号量例程三5.互斥量6.PV操作概念7.PV操作详解——抄自&#xff1a;https://mp.weixin.qq.com/s/vvjhbzsWQNRkU7-b_dURlQ8.PV操作的英文全称 1.信号量概念 …

HTTPS建立连接的过程

HTTPS 协议是基于 TCP 协议的&#xff0c;因而要先建立 TCP 的连接。在这个例子中&#xff0c;TCP 的连接是在手机上的 App 和负载均衡器 SLB 之间的。 尽管中间要经过很多的路由器和交换机&#xff0c;但是 TCP 的连接是端到端的。TCP 这一层和更上层的 HTTPS 无法看到中间的包…

拼多多API接口的使用方针如下:

了解拼多多API接口 拼多多API接口是拼多多网提供的一种应用程序接口&#xff0c;允许开发者通过程序访问拼多多网站的数据和功能。通过拼多多API接口&#xff0c;开发者可以开发各种应用程序&#xff0c;如店铺管理工具、数据分析工具、购物比价工具等。在本章中&#xff0c;我…

Spring中的设计模式

目录 工厂模式 组合模式 适配器模式 代理模式 单例模式 观察者模式 模板方法模式 责任链模式 Spring有着非常优雅的设计&#xff0c;很多地方都遵循SOLID原则&#xff0c;里面的设计模式更是数不胜数大概有以下几种&#xff1a; 工厂模式 所谓的工厂模式&#xff0c;核…

在MySQL中使用!=还能走索引吗?

在MySQL中使用!还能走索引吗&#xff1f; 一般情况下&#xff0c;我们会在一个索引上较多的使用等值查询或者范围查询&#xff0c;此时索引大多可以帮助我们极快的查询出我们需要的数据。 那当我们在where条件中对索引列使用!查询&#xff0c;索引还能发挥他的作用吗&#xf…

vue3 中使用 echarts 图表——准备篇

我们常常在项目中使用图表来表示数据&#xff0c;而目前最常用的图标就是echarts&#xff0c;接下来我们就开始学习在vue中使用echarts图标。 一、准备一个vue项目&#xff08;一般通过vite来构建&#xff0c;而不是vue-cli&#xff09; 1.找到打开vite官网 2. 运行创建命令 …

英语字典的一些 关键字 解释:

1. specialized &#xff1a;专业术语 这里的specialized 后面还接了 finance & economics 含义是 在经济和金融的领域&#xff0c;principal 作为一个专业术语&#xff0c;含义是 “本金&#xff0c;可生息资本” 2. XXXXXX

Web1.0——Web2.0时代——Web3.0

Web1.0 Web1.0是互联网的早期阶段&#xff0c;也被称为个人电脑时代的互联网。在这个阶段&#xff0c;用户主要通过web浏览器从门户网站单向获取内容&#xff0c;进行浏览和搜索等操作。在这个时代&#xff0c;技术创新主导模式、基于点击流量的盈利共通点、门户合流、明晰的主…

Vue-1.8生命周期

Vue生命周期 一个Vue实例从创建到销毁的整个过程。 生命周期&#xff1a; 1&#xff09;创建&#xff1a;响应式数据 ->发送初始化渲染请求 2&#xff09;挂载&#xff1a;渲染数据->操作dom 3&#xff09;更新&#xff1a;数据修改&#xff0c;更新视图 4&#xf…

028.Python面向对象_类补充_元类

我 的 个 人 主 页&#xff1a;&#x1f449;&#x1f449; 失心疯的个人主页 &#x1f448;&#x1f448; 入 门 教 程 推 荐 &#xff1a;&#x1f449;&#x1f449; Python零基础入门教程合集 &#x1f448;&#x1f448; 虚 拟 环 境 搭 建 &#xff1a;&#x1f449;&…