网易2020校招笔试(正式批)

tech2024-01-07  93

1.以下代码执行的结果是:

function fun () { return () => { return () => { return () => { console.log(this.name) } } } } var f = fun.call({name: 'foo'}) var t1 = f.call({name: 'bar'})()() var t2 = f().call({name: 'baz'})() var t3 = f()().call({name: 'qux'})

箭头函数没有自己的this也并不能使用call,apply以及bind去绑定this,会选择去继承父级作用域的this,所以后面几次的call实际上是失败的,所以箭头函数层层向上寻找name,只会在最外层的fun函数作用域中找到this指向{name: ‘foo’}对象的name属性。假设此处将fun函数改成箭头函数的声明方式,那么返回的值将会是undefined.

在call,apply,bind三个函数中,只有bind是返回bind后的函数,而并没有当场执行,apply和call不返回函数,当场执行。

2.下面代码执行结果是

const a = { valueOf() { return 'valueOf' }, toString() { return 'toString' }, get() { return 'get' } } alert(a)

这题考查valueOf()与toString()的区别。

在不重写这两个方法时:

toString()方法:返回对象的字符串表示 valueOf()方法:返回指定对象的原始值。 默认情况,会调用toString()方法。例如:

var cc = {}; alert(cc);// [object Object] var fun = function() {} ; alert(fun);// function() {} var arr = [1]; alert(arr); // 1

从上面的代码来看,默认情况会调用对象的toString()方法,返回对象的字符串表示。

下面看看重写对象的toString()与valueOf()方法,并且同时存在时会发生什么:

var bbb = { i: 10, toString: function() { console.log('toString'); return this.i; }, valueOf: function() { console.log('valueOf'); return this.i; } } alert(bbb);// 10 toString alert(+bbb); // 10 valueOf alert(''+bbb); // 10 valueOf alert(String(bbb)); // 10 toString alert(Number(bbb)); // 10 valueOf alert(bbb == '10'); // true valueOf

二者并存的情况下,在数值运算中,优先调用了valueOf,字符串运算中,优先调用了toString。而’ '+bbb是字符串操作,为啥也是调用valueOf,那是因为,存在操作符,valueOf的优先级高于toString。

3.有哪些常见的服务端推送的通信解决方案?它们的优劣分别是什么?

https://blog.csdn.net/sky1988818/article/details/86299900

4.跨域请求中,需要设置哪个属性为true,才能携带cookie信息?

实际上,这是浏览器的同源策略导致的问题:不允许JS访问跨域的Cookie。 举个例子,现有网站A使用域名a.example.com,网站B使用域名b.example.com,如果希望在2个网站之间共享Cookie(浏览器可以将Cookie发送给服务器),那么在设置的Cookie的时候,必须设置domain为example.com。因此要跨域共享cookie需要双边都设置 1.服务器端使用CROS协议解决跨域访问数据问题时,需要设置响应消息头Access-Control-Allow-Credentials值为“true”。 同时,还需要设置响应消息头Access-Control-Allow-Origin值为指定单一域名(注:不能为通配符“*”)。 2.客户端需要设置Ajax请求属性withCredentials=true,让Ajax请求都带上Cookie。

5.说一下用户从输入url到显示页面这个过程发生了什么

DNS解析 TCP连接 发送HTTP请求 服务器处理请求,返回HTTP报文 浏览器渲染页面 连接结束

Cookie、sessionStorage、localStorage的区别

共同点:都是保存在浏览器端,并且是同源的 Cookie:cookie数据始终在同源的http请求中携带(即使不需要),即cookie在浏览器和服务器间来回传递。而sessionStorage和localStorage不会自动把数据发给服务器,仅在本地保存。cookie数据还有路径(path)的概念,可以限制cookie只属于某个路径下,存储的大小很小只有4K左右。 (key:可以在浏览器和服务器端来回传递,存储容量小,只有大约4K左右) sessionStorage:仅在当前浏览器窗口关闭前有效,自然也就不可能持久保持,存储大小一般为5MB;localStorage:始终有效,窗口或浏览器关闭也一直保存,因此用作持久数据,存储大小一般为5MB;cookie只在设置的cookie过期时间之前一直有效,即使窗口或浏览器关闭。(key:本身就是一个回话过程,关闭浏览器后消失,session为一个回话,当页面不同即使是同一页面打开两次,也被视为同一次回话) localStorage:localStorage 在所有同源窗口中都是共享的;cookie也是在所有同源窗口中都是共享的。(key:同源窗口都会共享,并且不会失效,不管窗口或者浏览器关闭与否都会始终生效) 补充说明一下cookie的作用: 保存用户登录状态。例如将用户id存储于一个cookie内,这样当用户下次访问该页面时就不需要重新登录了,现在很多论坛和社区都提供这样的功能。 cookie还可以设置过期时间,当超过时间期限后,cookie就会自动消失。因此,系统往往可以提示用户保持登录状态的时间:常见选项有一个月、三个 月、一年等。 跟踪用户行为。例如一个天气预报网站,能够根据用户选择的地区显示当地的天气情况。如果每次都需要选择所在地是烦琐的,当利用了cookie后就会显得很人性化了,系统能够记住上一次访问的地区,当下次再打开该页面时,它就会自动显示上次用户所在地区的天气情况。因为一切都是在后 台完成,所以这样的页面就像为某个用户所定制的一样,使用起来非常方便定制页面。如果网站提供了换肤或更换布局的功能,那么可以使用cookie来记录用户的选项,例如:背景色、分辨率等。当用户下次访问时,仍然可以保存上一次访问的界面风格。

最新回复(0)