美文网首页
vue 面试题

vue 面试题

作者: 为光pig | 来源:发表于2021-01-11 17:28 被阅读0次

    1.vuex的理解及优缺点

    • vuex可以保存数组、对象、或者嵌套结构,不用toString
    • 双向绑定,使用commit修改一处状态后,所有引用的地方自动更新,不需要重新取值
    • 可以自定义数据过滤方法、取值方法、逻辑判断等
    • 可以在vuex里封装ajax,外部只负责调用数据

    2.vue-router

    1、hash模式

    随着 ajax 的流行,异步数据请求交互运行在不刷新浏览器的情况下进行。而异步交互体验的更高级版本就是 SPA —— 单页应用。单页应用不仅仅是在页面交互是无刷新的,连页面跳转都是无刷新的,为了实现单页应用,所以就有了前端路由。类似于服务端路由,前端路由实现起来其实也很简单,就是匹配不同的 url 路径,进行解析,然后动态的渲染出区域 html 内容。但是这样存在一个问题,就是 url 每次变化的时候,都会造成页面的刷新。那解决问题的思路便是在改变url的情况下,保证页面的不刷新。在 2014 年之前,大家是通过 hash 来实现路由,url hash 就是类似于:

    http://www.xxx.com/#/login
    

    这种 #。后面 hash 值的变化,并不会导致浏览器向服务器发出请求,浏览器不发出请求,也就不会刷新页面。另外每次 hash 值的变化,还会触发hashchange 这个事件,通过这个事件我们就可以知道 hash 值发生了哪些变化。然后我们便可以监听hashchange来实现更新页面部分内容的操作:

    function matchAndUpdate () {
       // todo 匹配 hash 做 dom 更新操作
    }
    
    window.addEventListener('hashchange', matchAndUpdate)
    

    2、history 模式

    14年后,因为HTML5标准发布。多了两个 API,pushState 和 replaceState,通过这两个 API 可以改变 url 地址且不会发送请求。同时还有popstate事件。通过这些就能用另一种方式来实现前端路由了,但原理都是跟 hash 实现相同的。用了HTML5的实现,单页路由的url就不会多出一个#,变得更加美观。但因为没有 # 号,所以当用户刷新页面之类的操作时,浏览器还是会给服务器发送请求。为了避免出现这种情况,所以这个实现需要服务器的支持,需要把所有路由都重定向到根页面。

    function matchAndUpdate () {
       // todo 匹配路径 做 dom 更新操作
    }
    
    window.addEventListener('popstate', matchAndUpdate)
    

    3.vue-router的使用

    3.1、动态路由匹配
    我们经常需要把某种模式匹配到的所有路由,全都映射到同个组件。例如,我们有一个 User 组件,对于所有 ID 各不相同的用户,都要使用这个组件来渲染。那么,我们可以在 vue-router 的路由路径中使用“动态路径参数”(dynamic segment) 来达到这个效果

    const User = {
      template: '<div>User</div>'
    }
    
    const router = new VueRouter({
      routes: [
        // 动态路径参数 以冒号开头
        { path: '/user/:id', component: User }
      ]
    })
    

    现在呢,像/user/foo 和 /user/bar 都将映射到相同的路由。

    一个“路径参数”使用冒号 : 标记。当匹配到一个路由时,参数值会被设置到this.$route.params,可以在每个组件内使用。于是,我们可以更新User的模板,输出当前用户的 ID:

    const User = {
      template: '<div>User {{ $route.params.id }}</div>'
    }
    

    提醒一下,当使用路由参数时,例如从/user/foo导航到/user/bar,原来的组件实例会被复用。因为两个路由都渲染同个组件,比起销毁再创建,复用则显得更加高效。不过,这也意味着组件的生命周期钩子不会再被调用。复用组件时,想对路由参数的变化作出响应的话,你可以简单地 watch (监测变化) $route 对象

    const User = {
      template: '...',
      watch: {
        '$route' (to, from) {
          // 对路由变化作出响应...
        }
      }
    }
    

    或者使用 2.2 中引入的 beforeRouteUpdate 守卫:

    const User = {
      template: '...',
      beforeRouteUpdate (to, from, next) {
        // react to route changes...
        // don't forget to call next()
      }
    }
    

    常见浏览器的兼容性问题

    1,浏览器兼容问题一:不同浏览器的标签默认的margin和padding不同

    问题症状:随便写几个标签,不加样式控制的情况下,各自的margin 和padding差异较大。

    碰到频率:100%

    解决方案:

    可以使用Normalize来清除默认样式,具体可参考文章:来,让我们谈一谈 Normalize.css

    也可以使用如下代码:

    *{margin:0;padding:0;}
    

    2,浏览器兼容问题二:块属性标签float后,又有横行的margin情况下,在IE6显示margin比设置的大
    问题症状:常见症状是IE6中后面的一块被顶到下一行

    碰到频率:90%(稍微复杂点的页面都会碰到,float布局最常见的浏览器兼容问题)

    解决方案:在float的标签样式控制中加入 display:inline;将其转化为行内属性

    备注:我们最常用的就是div+CSS布局了,而div就是一个典型的块属性标签,横向布局的时候我们通常都是用div float实现的,横向的间距设置如果用margin实现,这就是一个必然会碰到的兼容性问题。

    3,浏览器兼容问题三:设置较小高度标签(一般小于10px),在IE6,IE7,遨游中高度超出自己设置高度

    问题症状:IE6、7和遨游里这个标签的高度不受控制,超出自己设置的高度

    碰到频率:60%

    解决方案:给超出高度的标签设置overflow:hidden;或者设置行高line-height 小于你设置的高度。

    备注:这种情况一般出现在我们设置小圆角背景的标签里。出现这个问题的原因是IE8之前的浏览器都会给标签一个最小默认的行高的高度。即使你的标签是空的,这个标签的高度还是会达到默认的行高。
    4,清除浮动:

      .clearfix::after {
            content: "";
            display: table;
            clear: both;
        }
        
        .clearfix {
            *zoom: 1;
        }
    

    5、图片默认有间距
    问题表现:几个img标签放在一块,有些浏览器会有默认的间距,有通配符也不起作用

    解决方案:使用float属性为img布局

    备注:img标签是行内属性标签,只要不超出容器高度,img会排在一行里,使用float是比较好的选择

    6、标签最低高度设置min-height不兼容
    问题表现:min-height本身就是一个不兼容的css属性,所以设置min-height时不能兼容所有浏览器

    解决方案:如果设置一个标签最小高度为200px,需要进行设置 {min-height:200px; height:auto !important;

    height: 200px; overflow:visible;}

    备注:b/s系统前端时,当内容小于一个值时,容器的高度保持该值,当内容大于该值时,高度自适应且不出现滚动条。

    7、字体大小定义不同

    问题表现:对字体大小small定义不同,Firefox为13px,而IE为16px,差别比较大

    解决方法:使用指定的字体大小如14px或者使用em

    8.css hack

    先举一个小例子,简要说明一下CSS hack是干啥的。

    比如要分辨IE6和firefox两种浏览器,可以这样写:

    div{

    background:green;/forfirefox/

    background:red;/forIE6*/(bothIE6&&IE7)

    }

    我在IE6中看到是红色的,在firefox中看到是绿色的。

    解释一下:

    上面的css在firefox中,它是认识不了后面的那个带星号的东西是什么的,于是将它过滤掉,不予理睬,解析得到的结果是:div{background:green},于是理所当然这个div的背景是绿色的。

    在IE6中呢,它两个background都能识别出来,它解析得到的结果是:div{background:green;*background:red;},于是根据优先级别,处在后面的red的优先级高,于是当然这个div的背景颜色就是红色的了。

    css hack就是通过这种方式来对浏览器进行兼容性处理。也就是通过在CSS样式中加入一些特殊的符号,让不同的浏览器识别不同的符号(什么样的浏览器识别什么样的符号是有标准的,CSS hack就是让你记住这个标准),以达到应用不同的CSS样式的目的。因此我们就可以根据不同的浏览器去写不同的CSS,让它能够同时兼容不同的浏览器,能在不同的浏览器中也能得到我们想要的页面效果。

    针对不同浏览器的网站设计代码总结如下

    1、针对I E 系列浏览器的网站设计代码

    针对 IE 6 的专属 CSS Hack 网站设计代码 #id{ _display: block; } 也就是在网站设计CSS属性前加一个小划线就好。

    针对 IE 7 的专属 CSS Hack 网站设计代码 #id{ *display: block; } 即在网站设计CSS属性前加上一个星号。

    针对 IE 8 的专属 CSS Hack 网站设计代码 #id{ margin-top: 10px /9; /IE8/} 如上所示,解决办法为在网站设计CSS属性后分号前加上空格与斜线并加入一个数字9即可 。

    2、针对火狐的CSS Hack 网站设计代码

    想要解决火狐的兼容性只要将CSS代码写入到 @-moz-document url-prefix(){ } 里面就行了 , 例如 @-moz-document url-prefix() { #id{ display: block; } } 。

    3、针对 Safari 的CSS Hack 网站设计代码

    Safari是苹果中新的浏览器,解决兼容性的做法是加上@media screen and (-webkit-min-device-pixel-ratio:0)前缀。例如@media screen and (-webkit-min-device-pixel-ratio:0) { #id { display: block; } } 兼容性做法和火狐相近。

    4、针对 Opera 的CSS Hack 网站设计代码

    Opera解决兼容性的做法也是加上选择器前缀,例如 @media all and (-webkit-min-device-pixel-ratio:10000), not all and (-webkit-min-device-pixel-ratio:0) { head~body #id { display: block; } } 这个世界上必然不会存在绝对完美的事物,因此运用以上方法让我们的网站设计更好的与各种浏览器兼容的时候其实已经违反了网站制作的W3C标准。

    9.IE6下图片的下方有空隙
    解决方法:给img设置display:block;

    10.IE6下两个float之间会有个3px的bug
    解决办法:给右边的元素也设置float:left;

    11.IE6下没有min-width的概念,其默认的width就是min-width

    相关文章

      网友评论

          本文标题:vue 面试题

          本文链接:https://www.haomeiwen.com/subject/rjldaktx.html