【面试问题】—— 2019.3月前端面试之JS原理&CSS基础&Vue框架

前言:三月中旬面试了两家公司,一家小型公司只有面试,另一家稍大型公司笔试之后一面定夺。笔试部分属于基础类型,网上的复习资料都有。

面试时两位面试官都有考到一些实际工作中会用到,但我还没接触过的知识点。这里重点对这部分做一个梳理分析,主要是查阅资料补充。

(PS:多一年的工作经验,基础理论和实操能力都应该要深一层,要想在这行扎扎实实的有发展,真的很需要对自我的要求有一步步提高啊~)


第一家公司

一、outline与border的区别

在浏览器里,当鼠标点击或使用Tab键让一个链接或者一个radio获得焦点的时候,该元素将会被一个轮廓虚线框围绕。这个轮廓虚线框就是 outline 。

1、border 可应用于几乎所有有形的html元素,而 outline 是针对链接、表单控件和ImageMap等元素设计。

2、outline 的效果将随元素的 focus 而自动出现,相应的由 blur 而自动消失。这些都是浏览器的默认行为,无需JavaScript配合CSS来控制。

3、outline 不会象border那样影响元素的尺寸或者位置。

资料来源:https://my.oschina.net/guomingliang/blog/337169

 

二、用户使用输入框的过程使用到的事件?

这个问题还不知道完整的答案是什么,请大神能帮忙解答一下,感谢♪(・ω・)ノ

 

三、怎么看到用户上传文件的进度?

 

四、addEventListener()绑定事件中的false与true?什么时候用捕获?

事件捕获阶段:事件从最上一级标签开始往下查找,直到捕获到事件目标(target)。
事件冒泡阶段:事件从事件目标(target)开始,往上冒泡直到页面的最上一级标签。
 
什么时候用事件捕获呢?

 

五、事件代理

 

 

六、事件的属性和方法?(事件对象的公共成员)

属性/方法

说明

bubbles

表明事件是否冒泡

stopPropagation()

取消事件的进一步捕获或冒泡。如果bubbles为true,则可以使用这个方法

stopImmediatePropagation() 

取消事件的进一步捕获或冒泡,同时阻止任何事件处理程序被调用(DOM3级事件中新增)

cancelable

表明是否可以取消事件的默认行为

preventDefault()

取消事件的默认行为。如果cancelable是true,则可以使用这个方法

defaultPrevented

为true表示已经调用了preventDefault()(DOM3级事件中新增)

currentTarget

其事件处理程序当前正在处理事件的那个元素(currentTarget始终===this,即处理事件的元素

target

直接事件目标,真正触发事件的目标

detail

与事件相关的细节信息

eventPhase

调用事件处理程序的阶段:1表示捕获阶段,2表示处于目标阶段,3表示冒泡阶段

trusted

为true表示事件是由浏览器生成的。为false表示事件是由开发人员通过JavaScript创建的(DOM3级事件中新增)

type

被触发的事件的类型

view

与事件关联的抽象视图。等同于发生事件的window对象

 资料来源:http://www.cnblogs.com/starof/p/4096198.html

 

七、一个div设置为absolute,top为10,此时再设置为relative,它的浮动情况会是什么样的?

 

八、用CSS实现一个梯形?

  • 原理一:直接使用border

  1. 先设置box的width和height,实现内容content区域

    <div class='box'></div>
    
    .box{
           width:20px;
           height:20px;
           background-color:blue;
     }  

  2.  再给box添加四条边框样式,边框设置的宽一点, 四条边框的颜色给不一样的值, 方便查看

    .box{
          width:50px;
          height:50px;
          background-color:blue;
                
          border-top:50px solid red;
          border-right:50px solid yellow;
          border-bottom:50px solid green;
          border-left:50px solid pink;
    }

  3. 将box的高度(或宽度)设为0,上下border(或左右border)只保留一边,且设置的比剩下两边border(颜色透明)宽一些

    .box {
    	height:0;
    	width:100px;
    	border-bottom:100px solid #e5c3b2;  //设置梯形颜色
    	border-left:60px solid transparent;      //颜色透明    
    	border-right:60px solid transparent;    //颜色透明
    }
    

  • 原理二:使用三个box,分别在矩形元素前后加三角形

    <div class='box'></div>
    <div class='box2'></div>
    <div class='box3'></div>
    .box,.box3{
         width:0px;
         height:0px;
    
         border-top:50px solid rgba(0,0,0,0);
         border-right:50px solid  rgba(0,0,0,0);
         border-bottom:50px solid green;
         border-left:50px solid  rgba(0,0,0,0);
    
         margin-bottom:10px;
    }
    
    .box2{
         width:50px;
         height:50px;
         background-color:green;
    }
    
    //设置两个三角形的位移
    .box{
         transform: translate(54px,10px);
    }
    .box3{
         transform: translate(-54px,10px);
    }
  • 原理三:使用3d旋转矩形,使之看起来像矩形
    <div class="box"></div>
    
    .box{
            border-radius: .5em .5em 0 0;
            margin: 20px;
            height: 40px;
            width: 100px;
            background: #fb3;
            transform-origin: bottom;
            transform: scaleY(1.3) perspective(.5em) rotateX(5deg);
             /*scaleY: 纵轴放大1.3倍,使梯形高度等于height;perspective:3d透视效果,元素距离视图的距离*/
    }
    

      

      

资料来源:

https://www.cnblogs.com/linsinan/p/6928734.html

https://blog.csdn.net/dmtnewtons_blog/article/details/41146485

https://blog.csdn.net/wojiong132/article/details/66972023

 

九、说一下对Vue.js的理解?

 

十、为什么要用Vuex?

  • 与数据存储不同,Vuex 解决的主要问题是不同组件间的通信,以达到对当前页面数据状态的管理。既然是状态,它不会是持久化的,在页面刷新或关闭后,数据自动丢失。
    如果组件比较少,完全可以不用 Vuex
  • 目前有很多基于 Vuex 的插件,结合 localStorage、sessionStorage、IndexDB 等,可以达到数据持久化的目的。

 

第二家公司

笔试

一、怎么定义vue-router的动态路由?怎么获取传过来的动态参数? 

在router目录下的index.js文件中,对path属性加上/:id。  this.$route.params.id

易错:

vue-router的不同路由传值有2种,动态路由传值只有1种

1、get传值

<router-link to='/product?aid=123'></router-link>

this.$route.query

2、动态路由传值‘’

path: 'user/:id'

this.$route.params.id

 

二、v-model是什么?怎么使用?

  • v-model是双向数据绑定指令,本质上是一个语法糖。
    <input v-model="test">
    本质上是
    <input :value="test" @input="test = $event.target.value">  
  • @input是对<input>输入事件的一个监听,:value="test"是将监听事件中的数据放入到input
  • v-model不仅可以给input赋值,还可以获取input中的数据,而且数据的获取是实时的,因为语法糖中是用@input对输入框进行监听的。
    <div id="app">
      <input v-model="test">
      <!-- <input :value="test" @input="test= $event.target.value"> --><!--语法糖-->
      <h1>{test}</h1>
    </div>
    <script>
      new Vue({
        el: '#app',
        data: {
          test: '这是一个测试数据'
        }
      });
    </script>  

 

三、axios是什么?怎么使用?描述使用它实现登录功能的流程?

  • 请求后台资源的模块。(基于promise的http请求库)
  1. npm install axios -S装好;
  2. 然后发送的是跨域,需在配置文件中config/index.js进行设置;
  3. 后台如果是Thinkphp5则定义一个资源路由;
  4. js中使用import进来,然后.get或.post;
  5. 返回在.then函数中如果成功,失败则是在.catch函数中;

 

四、请详细说下你对vue生命周期的理解?

总共分为8个阶段创建前/后,载入前/后,更新前/后,销毁前/后。

  • 创建前/后: 在beforeCreate阶段,vue实例的挂载元素el和数据对象data都为undefined,还未初始化。在created阶段,vue实例的数据对象data有了,el还没有。
  • 载入前/后:在beforeMount阶段,vue实例的$el和data都初始化了,但还是挂载之前为虚拟的dom节点,data.message还未替换。在mounted阶段,vue实例挂载完成,data.message成功渲染。
  • 更新前/后:当data变化时,会触发beforeUpdate和updated方法。
  • 销毁前/后:在执行destroy方法后,对data的改变不会再触发周期函数,说明此时vue实例已经解除了事件监听以及和dom的绑定,但是dom结构依然存在

 

面试

一、vue-router有哪几种导航钩子?    

三种,
第一种:是全局导航钩子:router.beforeEach(to,from,next),作用:跳转前进行判断拦截。
第二种:组件内的钩子
第三种:单独路由独享组件

 

二、后端返回一张图片,前端如何将它显示在页面上?

转化为babel流即可,从数据库中读取出来的是个流数据,可以直接以流的形式写进去

 

三、Element UI组件库在使用时如何修改CSS?

原组件库的CSS有优先级,增加权重来解决样式覆盖问题:给父级定义一个类名或者Id来增加命名空间,达到不影响组件样式的目的

.aritle-page{ //你的命名空间
    .el-tag { //element-ui 元素
      margin-right: 0px;
    }
} 

 

四、什么是vue生命周期

  • Vue 实例从创建到销毁的过程,就是生命周期。也就是从开始创建、初始化数据、编译模板、挂载Dom→渲染、更新→渲染、卸载等一系列过程,我们称这是 Vue 的生命周期。
  • 它的生命周期中有多个事件钩子,让我们在控制整个Vue实例的过程时更容易形成好的逻辑。

 

五、宽高未知的情况下,如何居中div?

三个方法

方法1:通过定位和transform属性来实现

html:

<div class="parent">
    <div class="children">实现未知宽高元素垂直居中的方法1:通过定位和transform来实现</div>
</div>

css: 

<style>
     .parent{
         width:100%;
         height:400px;
         background:#666;
         position:relative;
     }
     .children{
         position:absolute;
         top:50%;
         left:50%;
         background:red;
         transform:translate(-50%,-50%);
     }
</style>  

 

方法2:通过利用flex布局

html:

<div class="parent">
    <div class="children">实现未知宽高元素的水平垂直居中方法2:主要是利用flex布局来实现</div>
</div>  

css:  

<style>
        .parent{
            width:100%;
            height:400px;
            background:#666;
            display:flex;
            align-items:center;
            justify-content:center;
        }
        .children{
            background:red;
        }
</style>

 

方法3:通过table属性  

html:

<div class="parent">
    <div class="children">实现未知宽高元素垂直水平居中,主要原理是将父元素设置为table,子元素设置为table-cell,利用table属性</div>
</div>

css:  

<style>
    .parent{
        display:table;
        width:100%;
        height:400px;
        background:#666;
    }
    .children{
        display:table-cell;
        vertical-align:middle;
        text-align:center;
        background:red;
    }
</style>

资料来源:https://blog.csdn.net/tozeroblog/article/details/79943579

 

六、get和post请求的区别?

  • get请求在URL中传送的参数是有长度限制的(2kb),而post没有。

  • get比post更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。

  • get参数通过URL传递,post放在Request body中。

  • get请求参数会被完整保留在浏览器历史记录里,而post中的参数不会被保留。

  • get请求只能进行url编码,而post支持多种编码方式。

  • get请求会被浏览器主动cache,而post不会,除非手动设置。

  • get产生的URL地址可以被Bookmark,而post不可以。

  • get在浏览器回退时是无害的,而post会再次提交请求。

 

七、请说说对缓存的理解?(cookie、sessionStorage、localStorage的区别)

特性cookiesessionStoragelocalStorage
数据生命期 生成时就会被指定一个maxAge值,这就是cookie的生存周期,在这个周期内cookie有效,默认关闭浏览器失效 页面会话期间可用 除非数据被清除,否则一直存在
存放数据大小 4K左右(因为每次http请求都会携带cookie) 一般5M或更大详细看这(需科学上网)
与服务器通信 由对服务器的请求来传递,每次都会携带在HTTP头中,如果使用cookie保存过多数据会带来性能问题 数据不是由每个服务器请求传递的,而是只有在请求时使用数据,不参与和服务器的通信
易用性 cookie需要自己封装setCookie,getCookie 可以用源生接口,也可再次封装来对Object和Array有更好的支持
共同点 都是保存在浏览器端,和服务器端的session机制不同(这里有一篇很好的介绍cookie和session的文章

 


注:转载请注明出处

posted @ 2019-04-03 17:01  柳洁琼Elena  阅读(638)  评论(1编辑  收藏  举报