1.对async、await的理解,内部原理?

①async---声明一个异步函数:
自动将常规函数转换成promise,返回值也是一个promise对象,
只有async函数内部的异步操作执行完,才会执行then方法指定的回调函数,内部可以使用await; ②await--暂停异步的功能执行:
放在promise调用之前,await强制其他代码等待,直到promise完成并返回结果,
只能与promise一起使用,不适用于回调,只能在async函数内部使用。
下面介绍下使用场景:
a.同时发出三个互不依赖的请求,
不建议使用 async/awaitasync function getABC() {
let A= await getValueA();//A needs 2 second
let B= await getValueB();//B needs 2 second
let C= await getValueC();//C needs 2 second
return A*B*C;
} 复制代码上图所示,
上面我们A需要2s,B需要4s,C需要3s,
我们如上图所示发请求,就存在彼此依赖的关系,c等b执行完,b等a执行完,
从开始到结束需要(++)9s。
此时我们需要用Promise.all()将异步调用并行执行,
而不是一个接一个执行, 如下所示: async function getABC() {
let results = await Promise.all([getValueA,getValueB,getValueC]);
return results.reduce((total,value)=>total*value)
} 复制代码这样将会节省我们不少的时间,从原来的的9s缩减到4s。
b.一个需要验证码提交表单的页面请求,
此时使用async/await会更好常规代码 const call1Promise = fetch('/#1...');
call1Promise.then(response=>response.json())
.then(json=>{
//验证码返回后的后续操作
const call2Promise = fetch('/#2...');
return call2Promise;
})
.then(response=>response.json())
.then(json=>{
console.log(json.respCode);
})
.catch(err=>{
console.log(err);
}) 复制代码用Async/Await的方式将逻辑分装在一个async函数里,
这样就可以直接对promise使用await了,也就规避了写then回调。
最后我们调用这个async函数,然后按照普通的方式使用返回的promise。
美哉! async function postForm(){
try{
//验证码是否通过,拿到返回的json
const response1 = await fetch('/#1...');
const json1 = await response1.json();
let json2;
//对第一个请求的返回数据进行判断
// 满足条件则请求第二个接口并返回数据
if(json1.respCode===){
const response2 = await fetch('/#2...');
json2 = await response2.json();
}
return json2;
}catch(e){
console.log(e);
}
} 简单的模拟场景
2.介绍下Promise,内部实现?
promise从字面上理解就是承诺,即未来完成的事儿。
从语法上来看,它是一个对象,
从它这里可以获取下一步操作的消息,
而promise对象的状态不受外部影响。 相关代码如下: const PENDING = 'pending'; //初始状态
const FULFILLED = 'fulfilled'; // 成功状态
const REJECTED = 'rejected'; // 失败状态
function Promise(extutor){
let self = this;
self.status = PENDING; // 设置状态
// 存放成功回调的数组
self.onResolveCallbacks = [];
// 存放失败回调的数组
self.onRejectedCallbacks = [];
function resolve(value){
if(self.status === PENDING){
self.status = FULFILLED;
self.value = value;
self.onResolveCallbacks.forEach(cb => cd(self.value))
}
}
function reject(reason){
if(self.status === PENDING){
self.status = REJECTED;
self.value = reason;
self.onRejectCallbacks.forEach(cb => cd(self.value))
}
}
try{
excutor(resolve, reject)
} catch(e) {
reject(e)
}
}

3.Http请求中的keep-alive有了解吗?

在http早期,每个http请求都要求打开一个tpc socket连接,
并且使用一次之后就断开这个tcp连接。
使用keep-alive可以改善这种状态,
即在一次TCP连接中可以持续发送多份数据而不会断开连接。
通过使用keep-alive机制,可以减少tcp连接建立次数,
也意味着可以减少TIME_WAIT状态连接,
以此提高性能和提高http服务器的吞吐率
(更少的tcp连接意味着更少的系统内核调用,socket的accept()和close()调用)。
但是,keep-alive并不是免费的午餐,长时间的tcp连接容易导致系统资源无效占用。
配置不当的keep-alive,有时比重复利用连接带来的损失还更大。
所以,正确地设置keep-alive timeout时间非常重要。

4.http中的状态码302代表的是什么意思?

302重定向表示临时性转移(Temporarily Moved ),
当一个网页URL需要短期变化时使用。
顺便提一嘴301301重定向/跳转一般,
表示本网页永久性转移到另一个地址。
301是永久性转移(Permanently Moved),SEO常用的招式,
会把旧页面的PR等信息转移到新页面301重定向与302重定向的区别
301重定向是永久的重定向,
搜索引擎在抓取新内容的同时也将旧的网址替换为重定向之后的网址。
302重定向是临时的重定向,
搜索引擎会抓取新的内容而保留旧的网址。
因为服务器返回302代码,
搜索引擎认为新的网址只是暂时的。

5.请描述utf-8和unicode的区别?

Unicode 是「字符集」UTF- 是「编码规则」Unicode是一套复杂的字符编码标准,
简单来说就是将人类使用的每个所谓字符与一个非负整数对应,
并且保证不同的字符对应的整数一定不同。
UTF-8是这个整数的编码方式,用1到4字节来表达一个整数。
关系:UTF-8是Unicode的实现方式之一,
它规定了字符如何在计算机中存储、传输等。

撩课-Web大前端每天5道面试题-Day21的更多相关文章

  1. 撩课-Web大前端每天5道面试题-Day10

    1. px和em的区别? px和em都是长度单位; 区别是: px的值是固定的,指定是多少就是多少, 计算比较容易. em得值不是固定的,并且em会继承父级元素的字体大小. 浏览器的默认字体高都是16 ...

  2. 撩课-Web大前端每天5道面试题-Day4

    1. 如何实现瀑布流? 瀑布流布局的原理: ) 瀑布流布局要求要进行布置的元素等宽, 然后计算元素的宽度, 与浏览器宽度之比,得到需要布置的列数; ) 创建一个数组,长度为列数, 里面的值为已布置元素 ...

  3. 撩课-Web大前端每天5道面试题-Day1

    1. var的变量提升的底层原理是什么? JS引擎的工作方式是: 1) 先解析代码,获取所有被声明的变量: 2)然后在运行.也就是说分为预处理和执行两个阶段. 变量提升:所有变量的声明语句都会被提升到 ...

  4. 撩课-Web大前端每天5道面试题-Day11

    1. 如何手写一个JQ插件? 方式一: $.extend(src) 该方法就是将src合并到JQ的全局对象中去: $.extend({ log: ()=>{alert('撩课itLike');} ...

  5. 撩课-Web大前端每天5道面试题-Day31

    1.web storage和cookie的区别? Web Storage的概念和cookie相似, 区别是它是为了更大容量存储设计的. Cookie的大小是受限的, 并且每次你请求一个新的页面的时候C ...

  6. 撩课-Web大前端每天5道面试题-Day25

    1.web前端开发,如何提高页面性能优化? 内容方面: .减少 HTTP 请求 (Make Fewer HTTP Requests) .减少 DOM 元素数量 (Reduce the Number o ...

  7. 撩课-Web大前端每天5道面试题-Day7

    1. 你能描述一下渐进增强和优雅降级之间的不同吗? 定义: 优雅降级(graceful degradation): 一开始就构建站点的完整功能, 然后针对浏览器测试和修复 渐进增强(progressi ...

  8. 撩课-Web大前端每天5道面试题-Day30

    1.什么叫优雅降级和渐进增强? 优雅降级: Web站点在所有新式浏览器中都能正常工作, 如果用户使用的是老式浏览器, 则代码会针对旧版本的IE进行降级处理了, 使之在旧式浏览器上以某种形式降级体验却不 ...

  9. 撩课-Web大前端每天5道面试题-Day23

    1.为什么用Nodejs,它有哪些优缺点? 优点: 事件驱动,通过闭包很容易实现客户端的生命活期. 不用担心多线程,锁,并行计算的问题 V8引擎速度非常快 对于游戏来说,写一遍游戏逻辑代码,前端后端通 ...

随机推荐

  1. 点分治&&动态点分治学习笔记

    突然发现网上关于点分和动态点分的教程好像很少……蒟蒻开篇blog记录一下吧……因为这是个大傻逼,可能有很多地方写错,欢迎在下面提出 参考文献:https://www.cnblogs.com/LadyL ...

  2. 使用putty连接本地VirtualBox上的centos7 linux主机

    1. 查看linux主机默认ssh端口 因为是使用ssh连接虚拟机上的linux主机的,所以需要查看centos ssh默认端口,一般是22 打开终端 输入cd /etc/ssh/ 查看ssh_con ...

  3. 重新设置Linux文件共享密码..

    今天同事把我主机踹倒了,鼠键都没反应,于是我在Linux运行的情况下强制重启了下电脑. 启动完了VMware后Linux重启,正常使用.后来我想起来有快照功能 之前也没用到过,于是就点了一下刚开始安装 ...

  4. flask-mysqldb安装时EnvironmentError: mysql_config not found

    安装时候的日志如下: sh: : mysql_config: not found Traceback (most recent call last): File , in <module> ...

  5. RabbitMQ - Start Up

    开始之前 rabbitmq是一个被广泛使用的消息队列,它是由erlang编写的,根据AMQP协议设计实现的. AMQP的主要特征是面向消息.队列.路由(包括点对点和发布/订阅).可靠性.安全. Rab ...

  6. 【NOI2013】快餐店 环套树+线段树

    题目大意:给你一颗环套树,你要在这棵的边上(包括端点)找一个点,使得离该点最远的点最近. 数据范围:$n≤10^5$,边权$≤10^9$. 此题不难看出一种暴力做法,我们依次断开环上的一条边,然后求整 ...

  7. 【poj3252】 Round Numbers (数位DP+记忆化DFS)

    题目大意:给你一个区间$[l,r]$,求在该区间内有多少整数在二进制下$0$的数量$≥1$的数量.数据范围$1≤l,r≤2*10^{9}$. 第一次用记忆化dfs写数位dp,感觉神清气爽~(原谅我这个 ...

  8. 无apk,怎么获取app的activity

    在做app自动化测试之前,有个前提条件,就是要获取当前app的包名和当前活动的activity.如果有提供了.apk,就可以直接通过adb命令获取到包名和欢迎页面:有种软件是手机自带的的,我们不知道a ...

  9. (转)十分钟了结MySQL information_schema

    十分钟了结MySQL information_schema  原文:http://www.cnblogs.com/shengdimaya/p/6920677.html information_sche ...

  10. java I/O系统总结

    1. InputStream : 从文件.网络.压缩包等中读取 需要的信息到程序中的变量 read();     read(byte []b ); mark(int readlimit); reset ...