vue-cli(vue脚手架)是vue官方提供的、快速生成vue工程化项目的工具。
特点:
①开箱即用
②基于webpack
③功能丰富且易于扩展
④支持创建vue2和vue3的项目
vue-cli的中文官网首页:https://cli.vuejs.org/zh/
安装:
vue-cli是基于Node.js开发出来的工具,因此需要使用npm将它安装为全局可用的工具:
默认情况下,在PowerShell中执行vue --version命令会提示如下的错误消息:
如何解决查看版本号的时候报错:
解决方案如下:
①以管理员身份运行PowerShell
②执行set-ExecutionPolicy RemoteSigned命令
③输入字符Y,回车即可
vue-cli提供了创建项目的两种方式:
步骤1:在终端下运行vue ui命令,自动在浏览器中打开创建项目的可视化面板:
步骤2:在详情页面填写项目名称:
步骤4:在功能页面勾选需要安装的功能(Choose Vue Version、Babel、CSS预处理器、使用配置文件)
步骤5:在配置页面勾选vue的版本和需要的预处理器:
步骤6:将刚才所有的配置保存为预设(模板),方便下一次创建项目时直接复用之前的配置:
步骤7:创建项目并自动安装依赖包:
vue ui的本质:通过可视化的面板采集到用户的配置信息后,在后台基于命令行的方式自动初始化项目:
项目创建完成后,自动进入项目仪表盘:
步骤1:在终端下运行vue create demo2命令,基于交互式的命令行创建vue的项目:
步骤2:选择要安装的功能:
步骤3:使用上下箭头选择vue的版本,并使用回车键确认选择:
步骤4:使用上下箭头选择要是用的css预处理器,并使用回车键确认选择:
主要的文件:
src->App.vue
src->main.js
在vue2的项目中,只能安装并使用3.x版本的vue-router
版本3和版本4的路由最主要的区别:创建路由模块的方式不同!
步骤1:在vue2的项目中安装3.x版本的路由:
在实际开发中,前端开发者可以把自己封装的.vue组件整理、打包、并发布为npm的包,从而供其他人下载和使用。这种可以直接下载并在项目中使用的现成组件,就叫做vue组件库。
二者之间存在本质的区别:
①PC端
②移动端
Element UI是饿了么前端团队开源的一套PC端vue组件库。支持在vue2和vue3的项目中使用:
开发者可以一次性完整引入所有的element-ui组件,或是根据需求,只按需引入用到的element-ui组件:
借助babel-plugin-component,我们可以只引入需要的组件,以达到减小项目体积的目的。
步骤1:安装babel-plugin-component:
步骤2:修改根目录下的babel.config.js配置文件,新增plugins节点如下:
步骤3:如果你只希望引入部分组件,比如Button,那么需要在main.js中写入以下内容:
拦截器会在每次发起ajax请求和得到响应的时候自动被触发。
应用场景:
①Token身份认证
②Loading效果
等等
通过axios.interceptors.request.use(成功的回调,失败的回调)可以配置请求拦截器。示例代码如下:
注意:失败的回调可以被省略。
借助于element ui提供的Loading效果组件(https://element.eleme.cn/#/zh-CN/component/loading)可以方便的实现Loading效果的展示:
通过axios.interceptors.response.use(成功的回调,失败的回调)可以配置响应拦截器。示例代码如下:
注意:失败的回调函数可以被省略!
调用Loading实例提供的close()方法即可关闭Loading效果,示例代码如下:
vue项目运行的地址:http://localhost:8080/
API接口运行的地址:http://www.escook.cn/api/users
通过vue-cli创建的项目在遇到接口跨域问题时,可以通过代理的方式来解决:
①把axios的请求根路径设置为vue项目的运行地址(接口请求不再跨域)
②vue项目发现请求的接口不存在,把请求转交给proxy代理
③代理把请求根路径替换为devServer.proxy属性的值,发起真正的数据请求
④代理把请求到的数据,转发给axios
①devServer.proxy提供的代理功能,仅在开发调试阶段生效
②项目上线发布时,依旧需要API接口服务器开启CORS跨域资源共享