vue基础笔试题
ctions 选项用来定义事件处理方法,用于处理 state 数据。actions 类似于 mutations,不同之处在于 actions 是异步执行的,事件处理函数可以接收 {commit} 对象,完成 mutation 提交,从而方便 devtools 调试工具跟踪状态的 state 变化。...............
目录
第一章 Vue.js基础入门
一、填空题
二、判断题
1.Vue 与 Angular 和 React 框架不同的是,Vue 设计为自下而上逐层应用。
2.Vue 完全能够为复杂的单页应用提供驱动。
3.Vue 是一套构建用户界面的渐进式框架,Vue 的核心只关注视图层。
4.Vue 中 MVVM 框架主要由 3 部分组成 :Model、View 和 View Model。
5.Vue 可以在 Node 环境下进行开发,并借助 npm 包管理器来安装依赖。
全对
三、选择题
1.下列关于 Vue 说法错误的是( )。
A.Vue 与 Angular 都可以用来创建复杂的前端项目
B.Vue 的优势主要包括轻量级、双向数据绑定
C.Vue 在进行实例化之前,应确保已经引入了核心文件 vue.js
D.Vue 与 React 语法是完全相同的2.下列关于 Vue 的优势的说法错误的是( )。
A.双向数据绑定
B.轻量级框架
C.增加代码的耦合度
D.实现组件化3.下列不属于 Vue 开发所需工具的是( )。
A.Chrome 浏览器
B.VS Code 编辑器
C.vue-devtools
D.微信开发者工具4.npm 包管理器是基于( )平台使用的。
A.Node.js
B.Vue
C.Babel
D.Angular5.下列选项中,用来安装 vue 模块的正确命令是( )。
A.npm install vue
B.node.js install vue
C.node install vue
D.npm I vue四、简答题
1.请简述什么是 Vue。
一套用于构建用户界面的渐进式框架,本身就是一个 js 文件,与其他大型框架相比,Vue 被设计为可以自底向上逐层应用。
2.请简述 Vue 优势有哪些。
1. 轻量级
2.双向数据绑定,MVVM 框架
3.指令,主要包括内置指令和自定义指令,以“ v- ”开头,作用于 HTML 元素。
4.插件,插件用于对 Vue 框架功能进行扩展,通过 MyPlugin.install 完成插件的编写,简单配置后就可以全局使用3.请简单介绍 Vue、React 之间的区别。
Vue 用 DOM 模板,React 依赖虚拟 DOM
五、编程题
1.请使用 Vue.js 动手创建 Vue 实例并实现数据的绑定效果。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="vue.js"></script> </head> <body> <div id="app"> {{msg}} </div> <script> var vm = new Vue({ el: '#app', data: { msg: 'hello world' } }) </script> </body> </html>
2.请手动配置 Vue.js 开发环境。
VS Code 编辑器
Vue 的下载和引入
官网下载 vue.js,通过 script 引入
git-bash 命令行管理工具(增强版的 cmd)
Node.js 环境
为什么要用 Node? 答:不能给用户源代码,我们选择通过 node 将项目暴露出去,然后普通用户就可以通过浏览器访问咱们的项目 1. 将项目交给 node 管理的过程,称之为项目部署/发布 2. node 管理项目之后,暴露出一个端口,我们通过 ip + 端口就可以访问 node 管理的这个项目 3. 我们的电脑如果通过 Node 运行了 Web 项目,那么我们的电脑就可以称之为服务器
npm 包管理工具(用来解决 Node.js 代码部署问题)
Chrome 浏览器插件 vue-devtools
webpack 打包工具(代码优化,并打包)
安装 webpack 和 webpack-cli npm install webpack webpack-cli -g -g:全局安装,即所有项目都能用
构建 Vue 项目
1. 安装脚手架 npm install vue-cli@2.9.x -g 2. 创建 webpack 模板的 Vue 项目 vue init webpack 项目名 3. 启动项目 npm run dev 就是运行 webpack-dev-server 官方提供的一个 express server,相当于是已经在开发者模式中发布了
第2章 Vue 开发基础(上)
一、填空题
二、判断题
1.在项目中引入了 vue.js 文件,才可以创建 Vue 实例。
2.Vue 实例对象指令主要包括自定义指令和内置指令,通过指令省去 DOM 操作。
3.Vue 事件传递方式有冒泡和捕获,默认是冒泡。
4.Vue 开发提出了组件化开发思想,每个组件都是一个孤立的单元。
5.在 Vue 中 beforeDestroy 与 destroyed 钩子函数执行后,都可以获取到 Vue 实例。
全对三、选择题
1.下列关于 Vue 实例对象说法不正确的是( )。
A.Vue 实例对象是通过 new Vue({})方式创建的
B.Vue 实例对象只允许有唯一的一个根标签
C.通过 methods 参数可以定义事件处理函数
D.Vue 实例对象中 data 数据不具有响应特性2.Vue 实例对象中能够监听状态变化的参数是( )。
A.watch
B.filters
C.watching
D.components3.Vue 中实现数据双向绑定的是( )。
A.v-bind
B.v-for
C.v-model
D.v-if4.在 Vue 中,能够实现页面单击事件绑定的代码是( )。
A.v-on:enter
B.v-on:click
C.v-on:mouseenter
D.v-on:doubleclick5.下面列出的钩子函数会在 Vue 实例销毁完成时执行的是( )。
A.updated
B.destroyed
C.created
D.mounted
四、简答题1.请简述什么是 Vue 实例对象。
var vm = new Vue()
vm 就是一个 Vue 实例对象,先通过 Vue 构造器创建实例,然后通过 new 关键字创建对象
2.请简述什么是 Vue 组件化开发
把一个大问题划分成若干小问题,逐个击破
组件还可复用,降低代码耦合度,提高开发效率
3.请简单介绍 Vue 数据绑定内置指令的主要内容有哪些。
v-bind 单向绑定,无交互
v-model 双向绑定,有交互
第3章 Vue 开发基础(下)
一、填空题
二、判断题
1.Vue 提供的全局 API 接口 component(),不能用来注册组件。
2.Vue 中 Vue.config 对象用来实现 Vue 全局配置。
3.Vue 中 data 选项中的数据具有响应特性。
4.Vue 中通过 vm .$slots 可以获取子组件实例对象。
5.Vue 实例对象中通过 $options 可以获取到父作用域下的所有属性。
F T T F F三、选择题
1.下列关于 Vue 实例对象接口的说法,错误的是( )。
A.Vue 实例对象提供了实例可操作方法
B.Vue 实例对象 $data 数据可以由实例 vm 委托代理
C.通过 Vue 实例对象可以进行 Vue 全局配置
D.Vue 实例对象接口同样可以通过 Vue 方式调用2.下面关于 Vue 全局配置的说法,错误的是( )。
A.Vue.config.devtools 可以设置 devtools 调试工具的启用和关闭
B.Vue.config 是一个对象,包含 Vue 的全局配置
C.Vue.component() 可以获取 Vue 全局配置对象
D.Vue.set.config 可以获取到全局配置对象==3.下列不属于 Vue 实例对象属性的是( )。
A. d a t a = = B.component==
C. p r o p s D.root4.Vue 实例对象获取子组件实例对象的方式是( )。
A. p a r e n t = = B.children==
C. c h i l d D.component5.下面关于 Vue.mixin 的说法,错误的是( )。
A.Vue.mixin 是 Vue 提供的全局接口 API
B.Vue.mixin 可以用来注入组件选项
C.使用 Vue.mixin 可能会影响到所有 Vue 实例
D.Vue.mixin 不可以用来注入自定义选项的处理逻辑
四、简答题1.请简述什么是 Vue 插件。
Vue 插件就是一个对象或函数,需要有 install 方法,可以通过 Vue.use 安装
let 自定义插件对象,然后写其 install 方法,最后用 Vue.use 安装插件
2.请简述 Vue 全局 API 接口的主要内容。
Vue.directive,自定义内置指令,例如 focus
Vue.use,安装插件
Vue.extend,为 Vue 构造器创建一个子类
Vue.set,向响应式对象中添加一个属性,并确保其也是响应式的
Vue.mixin,混入,影响全局 vue 实例
3.请简单介绍 Vue 实例对象的属性和方法。
vm.$props,接收上级组件向下级传递的数据
vm.options,Vue 实例初始化时传的自定义选项
vm.$el,访问根 DOM 元素
vm.$children,当前实例的直接子组件
vm.$root,组件树的根 Vue 实例
vm.$slot,查看插槽内容
vm.$attrs,组件属性
第四章 Vue 路由
一、填空题
二、判断题
1.后端路由通过用户请求的 URL 导航到具体的 html 页面。
2.开发环境下,使用 import VueRouter from ‘vueRouter’ 来导入路由。
3.嵌套路由的使用,主要是由页面结构来决定的。
4.params 方式传参类似于 GET 请求。
5.在单页面应用中更新视图可以不用重新请求页面
T F T F T三、选择题
1.下列 vue-router 插件的安装命令,正确的是( )。
A.npm install vue-router
B.node install vue-router
C.npm Install vueRouter
D.npm I vue-router2.下列关于 query 方式传参的说法,正确的是( )。
A.query 方式传递的参数会在地址栏展示
B.在页面跳转的时候,不能在地址栏看到请求参数
C.在目标页面中使用“this. route.query.参数名”来获取参数
D.在目标页面中使用“this.$route.params.参数名”来获取参数四、简答题
1.请简述以 npm 方式安装 vue-router 的步骤。
1.在指定目录下 npm install vue-router@3.1.x
2.创建 main.js 逻辑入口
import Vue from 'vue' import app from './App.vue' import VueRouter from 'vue-router' Vue.use(VueRouter) import router from './router.js' import './lib/mui/css/mui.css' new Vue({ el: '#app', render: c => c(app), router })
2.请简述 vue-router 路由的作用。
前端路由,用于切换页面,却不像后端路由那样每次切换页面都要请求服务器,响应快,提升用户体验
3.请简单列举并说明路由对象包括哪些属性
this.$router,全局路由对象
this.$route,当前路由对象
$route.path
$route.query:{key : value} URL 查询参数
$route.params:{key : value} 路由转跳携带参数
$route.hash:在 history 模式下获取当前路由的 hash 值(有 # 的那种)
$route.fullPath:完成解析后的URL,包含查询参数和 hash 的完整路径
$route.name
$route.matched:路由记录,当前路由下路由声明的所有信息,从父路由(如果有)到当前路由为止
$route.redirectedFrom:若有重定向,即为重定向来源的路由
第五章 Vuex
一、填空题
二、判断题
1.Vuex 实例对象可以调用 Vue 全局接口。
2.Vuex 中的 Vue.config 对象用来实现 Vuex 全局配置。
3.Vuex 的 state 选项中数据是初始数据状态。
4.Vuex 中插槽可以实现组件任意嵌套,且在版本 2.2.6+ 以后开始支持。
5.当在 Vuex 实例对象中调用 store 时,一定会获取到 store 实例对象。
F F T F T三、选择题
1. 下列关于 Vuex 实例对象接口的说法,错误的是( )。
A .Vuex 实例对象提供了 store 实例对象可操作方法
B.Vuex 实例对象 $data 数据可以由实例委托代理
C.通过 Vuex 实例对象可实现组件状态的管理维护
D .Vuex 实例对象初始数据是 state 数据
2.下面关于 Vuex 核心模块的说法,错误的是( )。
A .Vuex 配置对象中,actions 选项是异步的
B.Vuex.config 对象是全局配置对象
C.Vuex 配置对象中,mutations 选项是同步的
D .通过 commit 完成 mutations 提交
3.下列不属于 Vuex.Store 配置对象接收参数的是( )。
A .data
B.state
C.mutations
D .getters
4. Vuex 实例对象中类似于 computed 计算属性功能的选项是( )。
A .state
B.mutations
C.actions
D .getters
5.下面关于 Vuex 中的 actions 的说法,正确的是( )。
A .actions 中事件函数通过 commit 完成分发B.acitons 中事件处理函数接收 context 对象
C.actions 与 Vue 实例中的 methods 是类似的D .可以用来注入自定义选项的处理逻辑
四、简答题
1.请简要分析 Vuex 的设计思想。
用来管理状态,Vuex 作为 Vue 插件来使用,使 Vue 组件状态更加容易维护
2.简述 Vuex 配置对象中的主要内容有哪些。
1). actions:用来定义事件处理方法,用于处理 state 数据
2). mutations:选项中的事件处理方法接收 state 对象作为参数,即初始数据
3). getters:store 实例允许在 store 中定义 getters 计算属性,类似于 Vue 实例的 computed
4). modules:modules 用来在 store 实例中定义模块对象
5). plugins:Vuex 中的插件配置选项为 plugins,插件本身为函数
6). devtools:store 实例配置中的 devtools 选项用来设置是否在 devtools 调试工具中启用 Vuex,默认值为 true,表启用
3.简述 Vuex 中的 actions 的含义actions 选项用来定义事件处理方法,用于处理 state 数据。actions 类似于 mutations,不同之处在于 actions 是异步执行的,事件处理函数可以接收 {commit} 对象,完成 mutation 提交,从而方便 devtools 调试工具跟踪状态的 state 变化。
在使用时,需要在 store 仓库中注册 actions 选项,在里面定义事件处理方法。事件处理方法接收 context 作为第1个参数,payload 作为第 2 个参数(根据需要进行选择)。
第六章 Vue 开发环境
一、填空题
二、判断题
1.卸载 vue-cli 的命令是 npm uninstall vue-cli-g。
2.添加 CLI 插件的命令是 vue add vue-eslint。
3.插件不能修改 webpack 的内部配置,但是可以向 vue-cli-service 注入命令。
4.V ue CLI 通过 vue ui 命令来创建图形用户界面。
5.在文件中用 “key=value”(键值对)的方式来设置环境变量。
T F F T T三、选择题
1.下列选项中说法正确的是( )。
A .新版的 Vue CLI的包名称为 vue-cli
B.执行 npm uninstall vue-cli -g 命令可以全局删除 vue-cli 包
C.使用 yarn install add @ vue/cli 命令可以全局安装 @ vue/cli 工具
D .通过 vue add ui 命令来创建图形用户界面
2.关于 CLI 服务,下列选项说法错误的是( )。
A .在 @ vue/cli-service 中安装了一个名为 vue-cli-service 的命令
B.vue.config.js 是一个可选的配置文件
C.通过 npx vue-cli-service helps 查看所有的可用命令
D .通过 vue ui 使用 GUI 图形用户界面来运行更多的特性脚本
3.下列选项中说法正确的是( )。
A .使用相对路径引入的静态资源文件,会被 webpack 处理解析为模块依赖
B.放在 public 文件夹下的资源将会经过 webpack 的处理
C.通过绝对路径被引用的资源将会经过 webpack 的处理
D .URL 以~开始,会被认为是模块请求四、简答题
1.简述如何安装 Vue CLI 3.x 版本的脚手架。
npm install @vue/cli –g # -g 表示全局安装
2.简述如何在现有项目中安装 CLI 插件和第三方插件。
CLI 插件安装完成之后,在 package.json 文件中查看,是以 @vue/cli-plugin-开头。
注意:vue add 安装和调用只是 Vue CLI 插件,普通的 npm 包还是用 npm 来进行安装的。
例如 vue add @vue/eslint
第三方插件:
如果不带 @vue/ 前缀,将会安装第三方包
例如 vue add vuetify
3.简单介绍 CLI 服务 vue-cli-service 中的 command 命令包括哪些。
serve start development server 启动服务
build build for production 生成用于生产环境的包
inspect inspect internal webpack config 审查 webpack 配置
lint lint and fix source files lint?并修复源文件
五、编程题1.简单描述 Vue CLI 3 安装的过程。
如果之前已经全局安装了旧版的 vue-cli(1.x或2.x),需要先进行卸载,指令如下:
npm uninstall vue-cli -g
如果之前没有全局安装旧版,则直接全局安装@vue/cli脚手架,指令如下:
npm install @vue/cli –g
vue –V 查看版本号
2.简单描述使用 Vue CLI 3 创建项目的步骤。打开命令行工具,切换到项目根目录,执行以下指令来创建项目:
vue create hello-vue(项目名)
在交互界面中,选择手动配置项,进行配置
项目创建完成后,执行以下命令进去项目目录:
cd hello-vue
执行命令,启动项目
npm run server
1. Vue 实例的 data 属性,可以在哪些生命周期中获取到?
A. beforeCreate
B. created
C. beforeMount
D. mounted
2.下列对 Vue 原理的叙述,哪些是正确的?
A. Vue 中的数组变更通知,通过拦截数组操作方法而实现
B. 编译器目标是创建渲染函数,渲染函数执行后将得到 VNode 树
C. 组件内 data 发生变化时会通知其对应 watcher,执行异步更新
D. patching 算法首先进行同层级比较,可能执行的操作是节点的增加、删除和更新
3.对于 Vue 中响应式数据原理的说法,下列哪项是不正确的?
A. 采用数据劫持方式,即 Object.defineProperty() 劫持 data 中各属性,实现响应式数据
B. 视图中的变化会通过 watcher 更新 data 中的数据
C. 若 data 中某属性多次发生变化,watcher 仅会进入更新队列一次
D. 通过编译过程进行依赖收集
4.下列说法不正确的是哪项?
A. key 的作用主要是为了高效地更新虚拟 DOM
B. 若指定了组件的 template 选项,render 函数不会执行
C. 使用 vm.$nextTick 可以确保获得 DOM 异步更新的结果
D. 若没有 el 选项,vm.$mount(dom) 可将 Vue 实例挂载于指定元素上
5.下列关于 Vuex 的描述,不正确的是哪项?
A. Vuex 通过 Vue 实现响应式状态,因此只能用于 Vue
B. Vuex 是一个状态管理模式
C. Vuex 主要用于多视图间状态全局共享与管理
D. 在 Vuex 中改变状态,可以通过 mutations 和 actions
6.关于 Vue 组件间的参数传递,下列哪项是不正确的?
A. 若子组件给父组件传值,可使用 $emit 方法
B. 祖孙组件之间可以使用 provide 和 inject 方式跨层级相互传值
C. 若子组件使用 $emit(‘say’) 派发事件,父组件可使用 @say 监听
D. 若父组件给子组件传值,子组件可通过 props 接受数据
7.下列关于 vue-router 的描述,不正确的是哪项?
A. vue-router 的常用模式有 hash 和 history 两种
B. 可通过 addRoutes 方法动态添加路由
C. 可通过 beforeEnter 对单个组件进行路由守卫
D. vue-router 借助 Vue 实现响应式的路由,因此只能用于 Vue
8.下列说法不正确的是哪项?
A. 可通过 this.$parent 查找当前组件的父组件
B. 可使用 this.$refs 查找命名子组件
C. 可使用 this.$children 按顺序查找当前组件的直接子组件
D. 可使用 $root 查找根组件,并可配合 children 遍历全部组件
9.下列关于 v-model 的说法,哪项是不正确的?
A. v-model 能实现双向绑定
B. v-model 本质上是语法糖,它负责监听用户的输入事件以更新数据
C. v-model 是内置指令,不能用在自定义组件上
D. 对 input 使用 v-model,实际上是指定其 :value 和 :input
10.关于 Vue 的生命周期,下列哪项是不正确的?
A. DOM 渲染在 mounted 中就已经完成了
B. Vue 实例从创建到销毁的过程,就是生命周期
C. created 表示完成数据观测、属性和方法的运算和初始化事件,此时 $el 属性还未显示出来
D. 页面首次加载过程中,会依次触发
beforeCreate,created,beforeMount,mounted,beforeUpdate,updated
更多推荐
所有评论(0)