一般人我不告诉他(一)

作者: 张chuner | 来源:发表于2017-02-16 21:57 被阅读102次

    1、position的值, relative和absolute分别是相对于谁进行定位的?

    absolute :生成绝对定位的元素, 相对于最近一级的 定位不是 static 的父元素来进行定位。

    fixed (老IE不支持)生成绝对定位的元素,通常相对于浏览器窗口或 frame 进行定位。

    relative 生成相对定位的元素,相对于其在普通流中的位置进行定位。

    static 默认值。没有定位,元素出现在正常的流中

    sticky 生成粘性定位的元素,容器的位置根据正常文档流计算得出

    2、如何解决跨域问题

    JSONP:
    原理是:动态插入script标签,通过script标签引入一个js文件,这个js文件载入成功后会执行我们在url参数中指定的函数,并且会把我们需要的json数据作为参数传入。

    由于同源策略的限制,XmlHttpRequest只允许请求当前源(域名、协议、端口)的资源,为了实现跨域请求,可以通过script标签实现跨域请求,然后在服务端输出JSON数据并执行回调函数,从而解决了跨域的数据请求。

    优点是兼容性好,简单易用,支持浏览器与服务器双向通信。缺点是只支持GET请求。

    JSONP:json+padding(内填充),顾名思义,就是把JSON填充到一个盒子里

    <script>
    function createJs(sUrl){
    
        var oScript = document.createElement('script');
        oScript.type = 'text/javascript';
        oScript.src = sUrl;
        document.getElementsByTagName('head')[0].appendChild(oScript);
    }
    
    createJs('jsonp.js');
    
    box({
       'name': 'test'
    });
    
    function box(json){
        alert(json.name);
    }
    </script>
    

    3、XML和JSON的区别?

    (1).数据体积方面。
    JSON相对于XML来讲,数据的体积小,传递的速度更快些。

    (2).数据交互方面。
    JSON与JavaScript的交互更加方便,更容易解析处理,更好的数据交互。

    (3).数据描述方面。
    JSON对数据的描述性比XML较差。

    (4).传输速度方面。
    JSON的速度要远远快于XML。

    4、谈谈你对webpack的看法
    WebPack 是一个模块打包工具,你可以使用WebPack管理你的模块依赖,并编绎输出模块们所需的静态文件。它能够很好地管理、打包Web开发中所用到的HTML、Javascript、CSS以及各种静态文件(图片、字体等),让开发过程更加高效。对于不同类型的资源,webpack有对应的模块加载器。webpack模块打包器会分析模块间的依赖关系,最后 生成了优化且合并后的静态资源。

    webpack的两大特色:

    1.code splitting(可以自动完成)
    2.loader 可以处理各种类型的静态文件,并且支持串联操作

    webpack 是以commonJS的形式来书写脚本滴,但对 AMD/CMD 的支持也很全面,方便旧项目进行代码迁移。

    webpack具有requireJs和browserify的功能,但仍有很多自己的新特性:

    1. 对 CommonJS 、 AMD 、ES6的语法做了兼容
    2. 对js、css、图片等资源文件都支持打包
    3. 串联式模块加载器以及插件机制,让其具有更好的灵活性和扩展性,例如提供对CoffeeScript、ES6的支持
    4. 有独立的配置文件webpack.config.js
    5. 可以将代码切割成不同的chunk,实现按需加载,降低了初始化时间
    6. 支持 SourceUrls 和 SourceMaps,易于调试
    7. 具有强大的Plugin接口,大多是内部插件,使用起来比较灵活
      8.webpack 使用异步 IO 并具有多级缓存。这使得 webpack 很快且在增量编译上更加快

    5、说说TCP传输的三次握手四次挥手策略

    为了准确无误地把数据送达目标处,TCP协议采用了三次握手策略。用TCP协议把数据包送出去后,TCP不会对传送 后的情况置之不理,它一定会向对方确认是否成功送达。握手过程中使用了TCP的标志:SYN和ACK。

    发送端首先发送一个带SYN标志的数据包给对方。接收端收到后,回传一个带有SYN/ACK标志的数据包以示传达确认信息。 最后,发送端再回传一个带ACK标志的数据包,代表“握手”结束。 若在握手过程中某个阶段莫名中断,TCP协议会再次以相同的顺序发送相同的数据包。

    断开一个TCP连接则需要“四次握手”:
    第一次挥手:主动关闭方发送一个FIN,用来关闭主动方到被动关闭方的数据传送,也就是主动关闭方告诉被动关闭方:我已经不 会再给你发数据了(当然,在fin包之前发送出去的数据,如果没有收到对应的ack确认报文,主动关闭方依然会重发这些数据),但是,此时主动关闭方还可 以接受数据。

    第二次挥手:被动关闭方收到FIN包后,发送一个ACK给对方,确认序号为收到序号+1(与SYN相同,一个FIN占用一个序号)。

    第三次挥手:被动关闭方发送一个FIN,用来关闭被动关闭方到主动关闭方的数据传送,也就是告诉主动关闭方,我的数据也发送完了,不会再给你发数据了。

    第四次挥手:主动关闭方收到FIN后,发送一个ACK给被动关闭方,确认序号为收到序号+1,至此,完成四次挥手。

    6、创建ajax过程

    (1)创建XMLHttpRequest对象,也就是创建一个异步调用对象.
    (2)创建一个新的HTTP请求,并指定该HTTP请求的方法、URL及验证信息.
    (3)设置响应HTTP请求状态变化的函数.
    (4)发送HTTP请求.
    (5)获取异步调用返回的数据.
    (6)使用JavaScript和DOM实现局部刷新.

    7、渐进增强和优雅降级

    渐进增强 :针对低版本浏览器进行构建页面,保证最基本的功能,然后再针对高级浏览器进行效果、交互等改进和追加功能达到更好的用户体验。

    优雅降级 :一开始就构建完整的功能,然后再针对低版本浏览器进行兼容。

    8、HTTP和HTTPS

    HTTP协议通常承载于TCP协议之上,在HTTP和TCP之间添加一个安全协议层(SSL或TSL),这个时候,就成了我们常说的HTTPS。

    默认HTTP的端口号为80,HTTPS的端口号为443。

    9、Javascript垃圾回收方法

    1)标记清除(mark and sweep)
    这是JavaScript最常见的垃圾回收方式,当变量进入执行环境的时候,比如函数中声明一个变量,垃圾回收器将其标记为“进入环境”,当变量离开环境的时候(函数执行结束)将其标记为“离开环境”。

    垃圾回收器会在运行的时候给存储在内存中的所有变量加上标记,然后去掉环境中的变量以及被环境中变量所引用的变量(闭包),在这些完成之后仍存在标记的就是要删除的变量了

    2)引用计数(reference counting)
    在低版本IE中经常会出现内存泄露,很多时候就是因为其采用引用计数方式进行垃圾回收。引用计数的策略是跟踪记录每个值被使用的次数,当声明了一个 变量并将一个引用类型赋值给该变量的时候这个值的引用次数就加1,如果该变量的值变成了另外一个,则这个值得引用次数减1,当这个值的引用次数变为0的时 候,说明没有变量在使用,这个值没法被访问了,因此可以将其占用的空间回收,这样垃圾回收器会在运行的时候清理掉引用次数为0的值占用的空间。

    在IE中虽然JavaScript对象通过标记清除的方式进行垃圾回收,但BOM与DOM对象却是通过引用计数回收垃圾的, 也就是说只要涉及BOM及DOM就会出现循环引用问题。

    10、你觉得前端工程的价值体现在哪

    为简化用户使用提供技术支持(交互部分)
    为多个浏览器兼容性提供支持
    为提高用户浏览速度(浏览器性能)提供支持
    为跨平台或者其他基于webkit或其他渲染引擎的应用提供支持
    为展示数据提供支持(数据接口)

    11、谈谈性能优化问题

    (1)代码层面:避免使用css表达式,避免使用高级选择器,通配选择器。
    (2)缓存利用:缓存Ajax,使用CDN,使用外部js和css文件以便缓存,添加Expires头,服务端配置Etag,减少DNS查找等

    (3)请求数量:合并样式和脚本,使用css图片精灵,初始首屏之外的图片资源按需加载,静态资源延迟加载。

    (4)请求带宽:压缩文件,开启GZIP,

    代码层面的优化
      用hash-table来优化查找
      少用全局变量
      用innerHTML代替DOM操作,减少DOM操作次数,优化javascript性能
      用setTimeout来避免页面失去响应
      缓存DOM节点查找的结果
      避免使用CSS Expression
      避免全局查询
      避免使用with(with会创建自己的作用域,会增加作用域链长度)
      多个变量声明合并
      避免图片和iFrame等的空Src。空Src会重新加载当前页面,影响速度和效率
      尽量避免写在HTML标签中写Style属性
    

    12、移动端性能优化

    尽量使用css3动画,开启硬件加速。
    适当使用touch事件代替click事件。
    避免使用css3渐变阴影效果。
    可以用transform: translateZ(0)来开启硬件加速。
    不滥用Float。Float在渲染时计算量比较大,尽量减少使用
    不滥用Web字体。Web字体需要下载,解析,重绘当前页面,尽量减少使用。
    合理使用requestAnimationFrame动画代替setTimeout
    CSS中的属性(CSS3 transitions、CSS3 3D transforms、Opacity、Canvas、WebGL、Video)会触发GPU渲染,请合理使用。过渡使用会引发手机过耗电增加
    PC端的在移动端同样适用

    相关文章

      网友评论

        本文标题:一般人我不告诉他(一)

        本文链接:https://www.haomeiwen.com/subject/xgnhwttx.html