前端面试问题集(部分)

2019-03-21  本文已影响0人  我是一小白白
一、vue框架开发项目用到了哪些技术

vue + vuex + vue-router + axios + es6 + webpack

二、vuex 有什么作用

vuex用于程序开发的状态管理,它采用集中式存储,管理应用的所有组件的状态,每一个 Vuex 应用的核心就是 store(仓库)。“store”基本上就是一个容器,它包含着你的应用中大部分的状态 (state)。
使用:
1、在main.js中引入vuex:import Vuex from 'vuex',
然后挂载使用它:Vue.use(Vuex)
2、在main.js中加入:var store = new vuex.Store(){
state:{
count:0
}}

三、请求后台数据是如何请求的

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

四、vue路由怎么创建和使用
五、vue组件间怎么传值
六、vue组件怎么引用
  1. 编写子组件
  2. 在需要使用的父组件中通过import引入
  3. 在vue的components中注册
  4. 在模板中使用
七、mvvm开发模式介绍一下

module+view+viewModule,在MVVM的框架下视图和模型是不能直接通信的。它们通过ViewModel来通信,ViewModel通常要实现一个observer观察者,当数据发生变化,ViewModel能够监听到数据的这种变化,然后通知到对应的视图做自动更新,而当用户操作视图,ViewModel也能监听到视图的变化,然后通知数据做改动,这实际上就实现了数据的双向绑定。

八、vue中跨域如何处理

config/dev.env.js:

module.exports = merge(prodEnv, {

                                NODE_ENV: '"development"',//开发环境

                                API_HOST:"/api/"

                                })

axios发送get post请求问题
发送post请求时一般都要设置Content-Type,发送内容的类型,application/json指发送json对象但是要提前JSON.stringify()一下。application/xxxx-form指发送?
a=b&c=d格式,可以用qs.stringify()的方法格式化一下,qs在安装axios后会自动安装,只需要组件里import一下即可。
const postData=JSON.stringify(this.formCustomer);
'Content-Type':'application/json'}

const postData=Qs.stringify(this.formCustomer);//过滤成?&=格式
'Content-Type':'application/xxxx-form'}

九、如何判断用户的登录状态

vuex + localstorage (用于长期登录+判断用户是否已登录+适合长期保存在本地的数据)

十、页面已经更新,但是数据没有变化,浏览器缓存如何处理

<link rel="stylesheet" href="style.css" type="text/css" media="screen"/>

改一下css文件名:

<link rel="stylesheet" href="styleV2.css" type="text/css" media="screen"/>

<link rel="stylesheet" href="css/style.css?v=201708" />
将css文件的版本号改成新的:

<link rel="stylesheet" href="css/style.css?v=201709" />

十一、用户如果一直提交数据,怎么办

可以将提交的按钮状态更改,提交之后按钮变为不可用。

十二、get和post请求方式区别
十三、git如何处理版本冲突和新建合并分支
  1. git branch xxx (创建分支)
  2. git checkout xxx (检出)
  3. git merge (合并分支)
十四、数据双向绑定实现和原理

用v-module实现的,VUE实现双向数据绑定的原理就是利用了 Object.defineProperty() 这个方法重新定义了对象获取属性值(get)和设置属性值(set)的操作来实现的。

十五、webpack有什么作用,配置
十六、es6的一些写法
十七、H5 的一些新特性
  1. sessionStorage(会话期间有效,关闭浏览器窗口就失效,容量5M,不同页面或标签页面间无法共享,适用于敏感账号一次性登录)
  2. localStorage(本地存储永久有效,多窗口共享,容量5M,用于长期登录+判断用户是否已登录+适合长期保存在本地的数据)
十八、Html的语义化

1、在没有css的渲染下,依然能够清晰的看出页面的结构,方便开发人员开发。
2、语义化更有可读性,便于团队开发和维护。
3、便于seo,便于搜索引擎的搜索。

十九、cookie、sessionSttorage、localStory区别
二十、从输入网址到页面加载发生了什么

大概分为以下过程
DNS解析
TCP连接
发送HTTP请求
服务器处理请求并返回HTTP报文
浏览器解析渲染页面
连接结束

二十一、图片很多如何进行优化

可以进行懒加载或者是分页加载。

二十二、移动端适配怎么配置

viewport,三个属性
<meta name="viewport" content="width=device-width, initial-scale=1.0,user-scalable=0"

上一篇下一篇

猜你喜欢

热点阅读