摘要:异步管理等到执行完成后返回种状态,代表成功,代表失败。我们在函数内声明的变量叫局部变量,局部变量只能在里面访问,外面是访问不到的。那么就是为解决这一问题的。可以用链式写法等到异步有结果再进行下一步。
1. vue的双向绑定原理:
vue的双向绑定原理是通过Object.definedProperty的getter和setter来对属性进行数据劫持的。
因为Object.definedProperty最低是支持到浏览器IE9的,所以如果想要兼容IE8,只能去做Object.definedProperty的兼容,那最终使用的是做的兼容,而不是Object.definedProperty.
找了一张图片来表示响应原理。首先Object.definedProperty会对data的每个属性进行数据的劫持,当我们把data属性的值改了,就会触发它的setter,然后通知到watcher,watcher再更新指令所绑定的属性的值。
通过Observer对data做监听,并提供了订阅某个数据项变化的能力
把template编译成一段document fragment,然后解析其中的Directive,得到每一个Directive所依赖的数据项和update方法。
通过Watcher把上述2部分结合起来,即把Directive中的数据依赖通过Watcher订阅在对应数据的Observer的Dep上,当数据变化时,
就会触发Observer的Dep上的notify方法通知对应的Watcher的update,进而触发Directive的update方法来更新dom视图,最后达到模型和视图关联起来。
2. vue的钩子函数:依次为:beforeCreate ==> created ==> beforeMount ==> mounted ==> beforeUpdate ==> updated ==> beforeDestroy ==> destroyed
初始化的时候只有一次,只有当数据更改的时候才会去触发update钩子
computed是对结果进行缓存的,只要依赖的值没有变化,结果就不会变化。method就是普通的方法。computed减少执行的getter减去了重复计算,节省内存。watch是一直在监听。比如this.num + new Date(),虽然new Date的值一直在变,但只要this.num没变,结果还是一样的。
4. flex做骰子的3点:html:5. css的伪类:style: .box{ display:flex; } .item:nth-child(2){ align-self:center; } .item:nth-child(3){ align-self:right; }
:first-child/:last-children //选择第一个孩子,:nth-of-type(n) :checked/:disabled //选择checkbox已选中的 :afeter/:before //标签的伪类 :not(selecter) //非元素的其它元素6. 三行文本垂直居中:
1.加上下一样的padding值,达到上下居中的目的。
2.利用table
.wapper{ displaty:table; } .cell{ display:table-cell; vertical-align:center; }
3.{position:relative;top:50%;transform:translateY(-50%)}
4.通过box:
.center{ display:box; box-orient:horizontal; box-pack:center; box-align:center; }
5.flex:
7. 跨域的方法:.flex{ display:flex; align-items:center; }
浏览器为了安全机制,采用同源策略,域名,协议,端口号一致的才可以进行访问;
1,jsonp:是通过script标签的src属性来实现跨域的。通过src传过去一个函数,把数据放在函数的实参调用就可以拿到数据。由于是用src的链接,所以jsonp只支持get方式。content-type:javascript
2,cors:改变请求头信息。客户端加:Origin:地址。服务器:Access-Control-Allow-Origin:地址.支持IE10以上。
3,webpack:devServer里配置proxy:{api:"地址"};
4,nginx反向代理:
nginx.conf upstream tomcatserver{ server 192.168.72.49:8081//3.找到代理服务器的ip地址进行请求 } server{ listen 80; server_name 8081.max.com;//1.客户端调用名 location / { proxy_pass http://tomcatserver;//2.到代理服务器 index index.html index.html; } }8. webpack:
loader和plugins的区别:loader是负责解析代码的,而且plugins是去做优化,代码整合之类的。
new ExtractTextPlugin("styles.css"):分隔出css多带带打包;
new webpack.optimize.CommonsChunkPlugin({ name: "vendor", minChunks: function (module) { // 该配置假定你引入的 vendor 存在于 node_modules 目录中 return module.context && module.context.indexOf("node_modules") !== -1; } })//依赖项不重复打包,分隔模块
importLazy(import("./components/TodoHandler")), TodoMenuHandler: () => importLazy(import("./components/TodoMenuHandler")), TodoMenu: () => importLazy(import("./components/TodoMenu")), }}>//懒加载
解析es7用到的babel:babel-core,babel-loader,babel-preset-es2015,babel-preset-stage-2,babe-plugin-transform-runtime,babel-runtime,babel-register.
9. es6的声明方法,es5:var,function:var:会存在变量提升,如果在声明之前用到会报undefined.
let:不存在变量提升,如果在声明之前用到会报错。暂时性死区。块级作用域。
const:声明之后就不能改变。同上,如果是对象的话,只是指向引用的地址,所以对象里面的值改变了,是没有任何反应的。
function:声明属于window.function
class:声明一个类
import:声明一个引用过来的模块
压缩css,js:体积更小,加载速度更快。
css在前,js在后:css在前可以和dom树一起合成render树,js在后不阻塞dom渲染。
减少http请求:http请求需要时间。而且要等到它请求完才能执行。请求是异步的,不知道什么时候才能请求完。
webpack配置:按需加载。分离css。分隔依赖,把相同的依赖只打包到一起,不必重复加载。
promise:promise等到执行完成后返回2种状态,resolve代表成功,reject代表失败。
如果有多个异步可以用promise.all([]).
async await:async声明一个函数返回一个promise。await等到promise异步执行结束拿到的一个结果
脏值检测:angular在scope模型上设置了一个监听队列,用来监听数据变化并更新view,每次绑定一个东西到view上时angular就会往$watch队列插入一条$watch,用来检测它监视的model里是否有变化的东西(一个数据一个$watcher,对象会有一个,里面的值还会有,数组中每个对象也都会有一个)。这些$watch列表会在$digest循环中通过一个叫做‘脏值检测’的程序解析。
angular对大部分能产生数据变动的事件进行封装(如click,mouse-enter,timeout),在每次事件发生后,比如更改了scope中的一条数据,angular会自动调用$digest来触发一轮$digest循环,它会触发每个watcher,检查scope中的当前model值是否和上一次计算得到的Model值是否一样,如不同,对应的回调函数会被执行,调用该函数的结果,就是view中的表达式内容会被更新。
如果执行了非angular的方法,如setTimeout需要调用$apply()应用到angular上,它会调用$rootScope.$digest()。因此,一轮$digest循环在$rootScope开始,随后会访问到所有的children scope中的watchers。
$apply()里面可以加参数,而且会触发作用域树上所有的监控。$digest()只作用在当前作用域和它的子作用域上。
angular服务:sevicer对象的实例化this.xx=。factory返回一个对象return{a:xx}
13. 在arr=[1,2,4],4之前插入3arr.splice(2,0,3)14. json字符串与json对象的转换:
在数据传输过程中,json是以文本,即字符串的形式传递的。而js操作的是json对象。
转对象:str.parseJSON(),JSON.parse(str),eval("("+str+")")
转字符串:obj.toJSONString(),JSON.stringify(obj)
因为js是单线程的,setTimeout/setInterval是在定时器线程,要等主线程走完了,才会执行事件队列。如果主线程的计算执行时间过长,那么定时器就要一直等着不能执行,就导致了,动画卡,或者一下堆在一起执行重叠过快。
requestAnimationFrame不需要设置时间间隔。IE9以下不支持。cancelAnimationFrame()用来取消。
每一个构造函数都有自己的原型对象,用prototype属性来表示。每个原型对象都有一个隐式的_proto_属性指向它父级的原型对象。如:
let a= new A() a._proto_=A.prototype a._proto_._proto_=A.prototype._proto_=Object.prototype a._proto_._proto_._proto_=A.prototype._proto_._proto_=Object.prototype._proto_=null17. 闭包:
闭包简单来说就是函数套函数。我们在函数内声明的变量叫局部变量,局部变量只能在里面访问,外面是访问不到的。如果我们想访问局部变量就可以在函数的内部在写一个函数,根据作用域链的原则就可以往上找父级的变量。
闭包会导致内存泄露的问题,解决办法是用过之后把这个变量清空还原。
arguments是一个对应于传递给函数的参数的类数组对象。它是一个类似于数组的对象,但还不是数组。
arguments.length:实参长度。arguments.callee.length:形参长度
可以用[].slice.call(arguments);或Array.from(arguments);[...arguments]
get一般表示从服务器获取数据,post是向服务器传递数据。
get的方式是url,因为在地址栏所以长度有限,而且地址栏的内容可以看到,所以保密性较差。
而post是放在requst body。对长度没有限制,保密性也较好。
get一般用于搜索。post一般用于表单提交。
3 + "3" = 33 undefined + 3 = NaN //undefined为NaN, null + 3 = 3 //null为空。 "null" + 3 = "null3" 当有+的时候会检查是否有类型为string的,如果有就会把其它值也转化为string格式进行字符连接。如果没有string,有number,那么会把其它值转化为number类型的值执行加法运算。21. 循环
for(vari=0,j=0;i<5,j<10;i++,j++){ } console.log(i+j) //2022. 给数组加一个数组去重的方法:
Array.prototype.q=function(arr){ let obj={},a=[]; for(let i=0;i23. 类的继承: es6:extendses5:
1.构造函数绑定:function Cat(name,color){ Animal.apply(this,arguments); this.name=name; this.color=color; }2.利用prototype:
function Cat(name,color){ this.name=name; this.color=color; } Cat.prototype=new Animal(); Cat.prototype.constructor=Cat;3.组合继承:
function Cat(){ Animal.call(this) } Cat.prototype=new Animal();4.通过空对象:
function extend(Child,Parent){ var F=function(){}; F.prototype=Parent.prototype; Child.prototype=new F(); Child.prototype.constructor=Child; } function Animal(){} Animal.prototype.species="动物"; function Cat(name){ this.name=name; } extend(Cat,Animal)5.拷贝继承:
function extend2(Child,Parent){ var p=Parent.prototype; var c=Child.prototype; for(var i in p){ //浅拷贝 c[i]=p[i] } } extend2(Cat,Animal)24. map和forEach的区别:forEach不能breack,也不能return.
25. 获取url地址:
map循环每一个的时候就相当于在内存中新建了一个数据,比较占内存window.location.href26. async的好处:最开始的异步都是用回调函数解决的,比如ajax,setTimeout,addEventListener.但是如果回调函数过多就会形成回调地狱。那么promise就是为解决这一问题的。promise可以用链式写法等到异步有结果再进行下一步。但如果promise写多了也会变的不直观,async的await等到promise的返回。可以让代码看起来更加简洁高效。
27. 解构出a.b.c的值:let obj={a:{b:{c:1}}} let {a:{b:{c}}}=obj console.log(c) //128.react的生命周期: 29. angular与vue的对比: 30. 计算数组中元素出现的次数:请输入代码
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/95213.html
摘要:获取的对象范围方法获取的是最终应用在元素上的所有属性对象即使没有代码,也会把默认的祖宗八代都显示出来而只能获取元素属性中的样式。因此对于一个光秃秃的元素,方法返回对象中属性值如果有就是据我测试不同环境结果可能有差异而就是。 花了很长时间整理的前端面试资源,喜欢请大家不要吝啬star~ 别只收藏,点个赞,点个star再走哈~ 持续更新中……,可以关注下github 项目地址 https:...
摘要:好不容易在月号这天中午点左右接到了来自阿里的面试电话。这里会不断收集和更新基础相关的面试题,目前已收集题。面试重难点的和的打包过程多线程机制机制系统启动过程,启动过程等等扫清面试障碍最新面试经验分享,此为第一篇,开篇。 2016 年末,腾讯,百度,华为,搜狗和滴滴面试题汇总 2016 年未,腾讯,百度,华为,搜狗和滴滴面试题汇总 各大公司 Java 后端开发面试题总结 各大公司 Jav...
阅读 1364·2019-08-29 17:14
阅读 1623·2019-08-29 12:12
阅读 710·2019-08-29 11:33
阅读 3248·2019-08-28 18:27
阅读 1423·2019-08-26 10:19
阅读 883·2019-08-23 18:18
阅读 3460·2019-08-23 16:15
阅读 2520·2019-08-23 14:14