亚信科技前端实习面试题

一、Vue的生命周期

分为四个阶段:

1. 实例创建
2. DOM渲染
3. 数据更新
4. 销毁实例

共有八个生命周期函数:

1.beforeCreate —创建前
触发行为:vue挂载的$el和data都为undefined,还未初始化
在此阶段可以做的事情:加loading事件
2.created —创建后
触发行为:vue的数据对象data已经有数据了,$el还没有初始化
在此阶段可以做的事情:解决loading,请求ajax数据为mounted做准备
3.beforeMount --渲染前
触发的行为:vue实例和$el都初始化了,但还是虚拟的DOM节点
此阶段可以做的事情:也可以发请求拿数据
4.mounted —渲染后
触发的行为:vue实例挂载完成,页面以已经成功渲染
在此阶段可以做的事情:配合路由钩子函数使用
5.beforeUpdate —更新前
触发的行为:data更新前触发
6.updated —更新后
触发的行为:data更新前触发
在此阶段可以做的事情:数据更新时,做一些处理(此处也可以用watch进行观测)
7.beforeDestroy —销毁前
触发的行为:组件销毁前触发
在此阶段可以做的事情:可向用户询问是否销毁
8.destroyed —销毁后
触发的行为:组件销毁时触发,vue实例解除了事件监听和dom的绑定,但是dom阶段还存在
在此阶段可以做的事情:组件销毁进行提示

二、v-if和v-show的区别

1.都能动态控制元素的显示与隐藏
2.v-if是动态添加或删除整个DOM元素,v-if是为该元素添加display:none和block,DOM元素依旧还在
3.v-if切换有一个局部编译/卸载的过程,切换过程中合适的销毁和重建内部事件监听和子组件,v-show只是简单的进行css的切换
4.v-if是惰性的,如果条件为假,则什么都不做,只有条件第一次为真的时候才开始局部编译,v-show是任何条件下都被编译,然后被缓存,而且DOM元素保留
5.v-if有更高的切换消耗,v-show有更高的初始渲染消耗

三、vue2.0和vue3.0的区别

1.数据双向绑定原理发生了改变。
vue2.0使用的是Object.defineProperty数据劫持结合订阅者发布者实现的,vue3.0使用的是ES6的proxy实现的
2.vue2.0仅支持一个根节点,vue3.0支持多个根节点
3.声明周期函数不同,且vue3.0使用钩子函数需要先引入
vue2--------------vue3
beforeCreate -> setup()
created -> setup()
beforeMount -> onBeforeMount
mounted -> onMounted
beforeUpdate -> onBeforeUpdate
updated -> onUpdated
beforeDestroy -> onBeforeUnmount
destroyed -> onUnmounted
activated -> onActivated
deactivated -> onDeactivated
4.data和method和声明位置不一样。
vue2.0data和method是单独模块
vue3.0是都声明在setup函数中

四、输入一个url发生了什么

1.DNS域名解析(通过域名解析出IP)
2.建立TCP连接(根据域名和默认端口80和服务器建立连接)
3.浏览器读取文件(URL中域名后面部分对应文件)的HTTP请求,该请求消息作为TCP三次握手的第三个报文数据发给服务器(SYN敲门 SYN+ACK回应 ACK同意进门)
4.浏览器做出响应,并把对应的html文本发送给浏览器
5.释放TCP连接
6.浏览器解析html
7.浏览器解析html生成htmlDOM树
8.解析css生成cssDOM树
9.合并htmlDOM树和cssDOM树生成渲染树
10 布局和绘制,重绘和回流

五、隐藏一个元素的几种方法

  1. display:none
  2. opacty:0
  3. z-index进行覆盖
  4. visible:hidden

六、数组循环的几种方法

1.forEach
2.for in
3.for of
4.for循环
5.map

  • 6
    点赞
  • 96
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一页纸,刚看没有多少内容,也就半张纸的试题,可仔细看起来题目还挺多。有指针和引用的区别与联系,哪个更安全?为什么?类和结构体有什么联系和区别,相互之间能不能继承?还考了整型,指针,引用的sizeof。纳闷了,如今的笔试怎么都有求sizeof一些变量的。记得平时写代码的时候,都直接用了,谁还看他的值是多少? 第二部分让说了c/s的程序流程,编码部分有一个是树的广度优先遍历,当时一看就懵了,已经不看数据接构好多年了,忽然看了树,反而不知道怎么写了。还有一个是以空格分隔的字符串倒序输出,比如:I am a student,输出结果为:student a am I.字符串的操作相对还是比较熟一点。还让写了两个函数,分别是动态实现二维数组,以及如何释放二维数组,记得当时在大学的时候,好多课的上机也用过,不过记得不太清了,这些年都忘的差不多了,不过还好,面试官没说什么,就是说了释放有些问题,估计分配是对的。 最后一部分是关于自身的问题,比如自己的优缺点,并举例,自己对自己的评价,打分,朋友眼中的自己等等。那个纸太小了,幸好我的字也小,否则还真装不下那么多内容。连个草稿纸都不给。 答完后,面试官看了看,然后就些问题讨论了些。我的一些概念性的东西不是很清楚,我这人不喜欢看文字性的描述,给个图什么都明白了。他说我花了一个小时的时间完成,说男生做的会快些,然后又说女生能做成这样已经很好了。当时就想难道女生就该慢,我没有告诉他我答题的期间接了个电话,还有人来会议室搬椅子,我做完了还在想什么时候给他说。呵呵,那我也不算慢了。 他问了以前是否加过班,能加多少,本想说一年加多少次,后来想太少了,就说一个月加一两次。然后就看到他的嘴角稍微裂了裂。估计他们要加班多吧!之后又问了我所知道他们公司的一些信息,所做的业务。我说了一些基本的信息,又说了boss系统和bi系统。他就问我什么是boss系统,他可能以为我会不知道,没想到我早就上网查好了,脱口就说是:业务操作支持系统。其实boss系统包括四部分,我也查了而且也背过了,只是没有说。他想为难我但是没有达到目的,这已经足够了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值