当前位置: 首页 > news >正文

前端_面试

<!--变量提升-->
<p>当执行JS代码时,会生成执行环境,代码不是在全局执行环境中,就是在函数执行环境中.
JS解释器在解释一段代码时,第一阶段:对于var 会先找出来进行变量提升,给它们在内存提前开辟好空间,函数的话会将整个函数存入内存中,变量只声明并且赋值为undefined,第二阶段,代码执行.</p>
<!--bind call apply区别-->
<p>call和apply都可以解决this指向,作用域是相同的,传参的方式不同.call可以接收一个参数列表,apply只接收一个参数数组.bind方法会返回一个函数,且通过bind实现柯里化.</p>
<!-- ==与 ===的区别-->
<!-- 前端优化-->
<p>
1.css样式表放在页面头部Header内且Link链式接入,javaScript放在底部body结束标签前避免堵塞.
2.代码压缩:html/css/js/图片进行压缩,图片预加载,懒加载,图片加载使用TinyPNG.
3.减少DOM元素数量且减少使用:after等伪类的使用,有效避免页面重绘/重排.
4.不常变动的静态资源采用CDN分发,img标签设置高宽,减少页面重排/重绘,使用WebP格式图片,对原图进行98%压缩.
5.域名拆分:增加了浏览器请求的并发数,让浏览器能同时发起更多的请求,解决默认携带的Cookie问题,减少数据传输字节.
通常分为三类:前端类:业务代码本身html,css,js,图片等. 静态类:CDN资源类 动态类:后端API接口类.
6.合理使用dns-prefetch, prefetch,preload,defer,async;
</p>

<!--前端面试-->
<h3>JavaScript</h3>
<p>执行上下文,尤其是词法作用域和闭包.提升机制,函数与块级作用域,以及函数表达式和声明</p>
<p>绑定,特别是bind,apply,this关键字,对象原型,构造函数和mixins,组合函数和高阶函数.</p>
<p>时间委托和冒泡,typeof instanceof和object.prototype,toString</p>
<p>使用回调,promiss和await和async处理异步调用.使用函数声明和表达式</p>

<h3>DOM</h3>
<p>如何遍历和操作DOM,包括使用document.querySelector和旧浏览器中的document.getElementsByTagName选择或查找节点。上下遍历(Node.parentNode,Node.firstChild,Node.lastChild和Node.childNodes),左右遍历(Node.previousSibling和Node.nextSibling)在DOM树中添加,删除,复制和创建节点,以及切换,删除或添加CSS类名等操作。</p>

<h3>CSS</h3>
<p>布局</p>

<h3>HTML</h3>
<p></p>

性能优化

页面性能优化

(1)函数节流:一个函数执行一次后,只有大于设定的执行周期才会执行第二次.
(2)函数防抖:一个需要频繁触发的函数,只有在规定时间内,只让最后一次生效,前面的不生效.
(3)资源压缩与合并(html压缩,css压缩,js压缩,文件合并与压缩)
(4)非核心代码异步加载
(5)利用浏览器缓存.
(6)预解析DNS.

相关文章:

  • 67 亿美金搞个图,创建知识图谱的成本有多高你知道吗?
  • 重学前端-css选择器
  • 对象引论
  • Windows Core OS预计将更多地依赖于这些组件
  • 【技术性】Search知识
  • 什么是Javascript函数节流?
  • C语言小程序-基于链表的学生信息管理
  • js基础
  • 前嗅ForeSpider教程:创建模板
  • spring cloud构建互联网分布式微服务云平台-SpringCloud集成项目简介
  • MySQL无法启动几种常见问题小结
  • C语言笔记(第一章:C语言编程)
  • sqoop使用手册--mysql配置
  • width 值 max-content、fill-available、min-content 对应作用
  • multimap详讲
  • 【RocksDB】TransactionDB源码分析
  • 【许晓笛】 EOS 智能合约案例解析(3)
  • 【译】理解JavaScript:new 关键字
  • Angular数据绑定机制
  • Git学习与使用心得(1)—— 初始化
  • HashMap ConcurrentHashMap
  • Java Agent 学习笔记
  • javascript 总结(常用工具类的封装)
  • overflow: hidden IE7无效
  • Python实现BT种子转化为磁力链接【实战】
  • Rancher-k8s加速安装文档
  • vue:响应原理
  • Vue源码解析(二)Vue的双向绑定讲解及实现
  • Webpack入门之遇到的那些坑,系列示例Demo
  • windows-nginx-https-本地配置
  • 阿里中间件开源组件:Sentinel 0.2.0正式发布
  • 驱动程序原理
  • 数组的操作
  • 学习HTTP相关知识笔记
  • shell使用lftp连接ftp和sftp,并可以指定私钥
  • # 执行时间 统计mysql_一文说尽 MySQL 优化原理
  • ## 临床数据 两两比较 加显著性boxplot加显著性
  • #ifdef 的技巧用法
  • #在 README.md 中生成项目目录结构
  • $redis-setphp_redis Set命令,php操作Redis Set函数介绍
  • (C#)Windows Shell 外壳编程系列4 - 上下文菜单(iContextMenu)(二)嵌入菜单和执行命令...
  • (NO.00004)iOS实现打砖块游戏(九):游戏中小球与反弹棒的碰撞
  • (二) Windows 下 Sublime Text 3 安装离线插件 Anaconda
  • (汇总)os模块以及shutil模块对文件的操作
  • (免费领源码)python+django+mysql线上兼职平台系统83320-计算机毕业设计项目选题推荐
  • (转)JVM内存分配 -Xms128m -Xmx512m -XX:PermSize=128m -XX:MaxPermSize=512m
  • .NET CF命令行调试器MDbg入门(二) 设备模拟器
  • .NET Core Web APi类库如何内嵌运行?
  • .NET Standard / dotnet-core / net472 —— .NET 究竟应该如何大小写?
  • .netcore如何运行环境安装到Linux服务器
  • .Net程序帮助文档制作
  • .NET建议使用的大小写命名原则
  • .net解析传过来的xml_DOM4J解析XML文件
  • .NET委托:一个关于C#的睡前故事
  • .NET项目中存在多个web.config文件时的加载顺序