前端模块化开发的理解 RequireJS CommonJS AMD CMD
CommonJS,因为在网页端没有模块化编程只是页面JavaScript逻辑复杂,但也可以工作下去,在服务器端却一定要有模块,所以虽然JavaScript在web端发展这么多年,第一个流行的模块化规范却由服务器端的JavaScript应用带来,CommonJS规范是由NodeJS发扬光大,这标志着JavaScript模块化编程正式登上舞台。
定义模块
根据CommonJS规范,一个单独的文件就是一个模块。每一个模块都是一个单独的作用域,也就是说,在该模块内部定义的变量,无法被其他模块读取,除非定义为global对象的属性
模块输出:
模块只有一个出口,module.exports对象,我们需要把模块希望输出的内容放入该对象
加载模块:
加载模块使用require方法,该方法读取一个文件并执行,返回文件内部的module.exports对象
AMD即Asynchronous Module Definition,中文名是异步模块定义的意思。它是一个在浏览器端模块化开发的规范
由于不是JavaScript原生支持,使用AMD规范进行页面开发需要用到对应的库函数,也就是大名鼎鼎RequireJS,实际上AMD 是 RequireJS 在推广过程中对模块定义的规范化的产出
requireJS主要解决两个问题
多个js文件可能有依赖关系,被依赖的文件需要早于依赖它的文件加载到浏览器
js加载的时候浏览器会停止页面渲染,加载文件越多,页面失去响应时间越长
页面优化
设计思路 观察者模式的理解
ajax的问题归总
status状态码的种类和http状态码相同
url 是否能随便引用
不能接口必须是相同端口
ajax请求 有几种callback
Ajax请求总共有八种Callback
- onSuccess
- onFailure
- onUninitialized
- onLoading
- onLoaded
- onInteractive
- onComplete
- onException 跨端口导致跨域问题
true代表异步false代表同步跨域不只是说跨不同的域,而是包括协议、主机ip、端口三个。 tomcat服务器不存在此类问题,tomcat服务器的cors设置了同ip不同port可以访问。 而我使用的django自带的开发服务器,没有设置cors。
TCP协议和UDP协议的区别是什么
TCP是美国国防部设计的两种传输协议之一,另一种是UDP。UDP是一种不可靠的网络服务,负载比较小,而TCP则是一种可靠的通信服务,负载相对而言比较大
JSONP原理与实现
通过 script的src引用
而且是动态产生script,请求回来的内容通过callback处理
JSONP(JSON with Padding)是一个非官方的协议,它允许在服务器端集成Script tags返回至客户端,通过javascript callback的形式实现跨域访问。
由于同源策略的限制,XmlHttpRequest只允许请求当前源(域名、协议、端口)的资源,为了实现跨域请求,可以通过script标签实现跨域请求(因为同源策略不阻止动态脚本插入,并且将脚本看作是从提供 Web 页面的域上加载的),然后在服务端输出JSON数据并执行回调函数,从而解决了跨域的数据请求。
通过动态添加script标签,然后指定callback函数,可以获取到传过来的json数据,这时候要自己写一个callback函数来处理数据;
es5 数组的新方法
forEach 循环遍历
map 映射 [].map();
filter 过滤,筛选
some 某些,指的是某些项合乎条件。于every算是好基友,every表示是否‘每一项’都要靠谱
回调是什么
react中的 props 和 state 的一些细节
state的作用
state是React中组件的一个对象.React把用户界面当做是状态机,想象它有不同的状态然后渲染这些状态,可以轻松让用户界面与数据保持一致.
React中,更新组件的state,会导致重新渲染用户界面(不要操作DOM).简单来说,就是用户界面会随着state变化而变化.
==setstate改变,不影响其他的state setState异步更新==
props的作用
组件中的props是一种父级向子级传递数据的方式
props是不可变的;而state可以根据与用户交互来改变
React基于状态实现对DOM控制和渲染;组件状态分为两种;
1:组件间的状态传递;(props) props从父组件到子组建的数据传递
2:组件的内部状态; (state) state只能定义在组件内部;定义组件的自己的状态
React中的数据流是单向的;只会从父组件传递到子组件;属于props;
属性props是父子组件间进行状态传递的接口;React会向下遍历整个组件树;并从新渲染使用这个属性的组件;
props传值是怎么来的,通过父级,父子的值是怎么来的,是通过页面设置传进来的
this的指向
es6的箭头函数this的作用域指向自己本身
es6 let const的好处说明
DOCTYPE的作用,写出几个文档类型
前端的一些算法
回文 冒泡排序/快排 二叉树的理解 数组去重 选出出现最多的字符 在不创建变量的情况下A B 变量互换
ev.stopPropagation()
阻止冒泡
一个页面从URL到加载显示完成,都发生了什么?
- ①通过DNS将该地址解析成IP地址;
- ②发起网络连接,进行http协议会话:客户端发送报头(请求报头),服务端回馈报头(响应报头)
- ③返回一个页面(根据页面上的外链的URL重新发送请求获取)
- ④接收文件完毕,对加载到的资源进行语法解析,以及相应的内部数据结构(网页渲染)
前端安全方面有没有了解?XSS和CSRF如何攻防?
CSRF(Cross-site request forgery)是跨站请求伪造。XSS利用站点内的信任用户,而CSRF则通过伪装来自受信任用户的请求来利用受信任的网站。其实就是攻击者盗用了你的身份,以你的名义发送恶意请求。
XSS(Cross Site Scripting)是跨站脚本攻击,为了区分CSS,所以缩写为XSS。恶意攻击者往Web页面里插入恶意Script代码,当用户浏览该页之时,嵌入其中Web里面的Script代码会被执行,从而达到恶意攻击用户的目的。
CSRF的防御
1.在表单里增加Hash值,以认证这确实是用户发送的请求,然后在服务器端进行Hash值验证。
2.验证码:每次的用户提交都需要用户在表单中填写一个图片上的随机字符串。
XSS漏洞修复
1.将重要的cookies标记为HTTP ONLY。
2.只允许用户输入我们期望的数据。如年龄框只能输入数字。
3.对数据进行HTTP Encode处理。
4.过滤或者移除特殊的HTML标签。
5.过滤JS事件的标签。
es6的箭头函数
webpack是什么
简单的说就是 web 打包工具;也是前端模块化的工具
有以下四个特点
- 代码拆分 按需加载相应的静态资源,实现单页应用
- Loader 对一些文件进行进一步的解释和翻译,如 对css的lass
- 智能解析 会自动的形成依赖树
- 插件系统 自身有丰富的插件系统
webpack的核心概念
入口起点(entry points)
输出(output)
加载器(loaders)
插件(plugins)
react+webpack+express
是干啥的 为啥这么用
react路由的实现
静态还是动态的
前端缓存
页面怎么渲染的
dom树
css树
合成render树
再加载js
js会阻塞加载
引用数据类型
隐式原型__proto__
显示原型 prototype 只有fn有
href src的区别
做过兼容性
微信公众号开发
熟练掌握Web以及Mobile Web开发相关技术
引用数据类型
性能优化
减少CPU计算,减少网络请求
多实用内存,缓存
加载页面和静态页面
静态资源的合并和压缩
静态资源缓存
使用CDN让资源加载更快
使用SSR后端渲染
css放前面,js放后面
懒加载
减少dom查询
减少dom操作
事件节流
DOMContentLoaded
post是如何传职的
异步是什么
哪几个标签可以进行异步
前端的存储方式
页面是如何渲染的 细节
前端express的用处
为什么使用node,哪些场景使用
前后端分离是什么,有什么好处
1 | webpack 优化 |
1 | 面试记录 |