第 3 章:使用 Vue 脚手架
3.1 初始化脚手架
3.1.1 说明
-
Vue 脚手架是 Vue 官方提供的标准化开发工具(开发平台)。
-
最新的版本是 4.x。
3.1.2 具体步骤
第0步下载缓慢请配置 npm 淘宝镜像:
npm config set registry https://registry.npm.taobao.org
第一步(仅第一次执行):全局安装@vue/cli。
npm install -g @vue/cli
第二步:切换到你要创建项目的目录,然后使用命令创建项目
vue create xxxx
第三步:启动项目
npm run serve
补充: Vue 脚手架隐藏了所有 webpack 相关的配置,若想查看具体的 webpakc 配置, 请执行: vue inspect > output.js
3.1.3 模板项目的结构
├── node_modules
├── public
│ ├── favicon.ico: 页签图标
│ └── index.html: 主页面
├── src
│ ├── assets: 存放静态资源
│ │ └── logo.png
│ │── component: 存放组件
│ │ └── HelloWorld.vue
│ │── App.vue: 汇总所有组件
│ │── main.js: 入口文件 ├── .gitignore: git 版本管制忽略的配置
├── babel.config.js: babel 的配置文件
├── package.json: 应用包配置文件 ├── README.md: 应用描述文件 ├── package-lock.json:包版本控制文件
3.2 ref 与 props
ref
1. 作用:用于给节点打标识 2. 读取方式:this.$refs.xxxxxx
props
-
作用:用于父组件给子组件传递数据
-
读取方式一: 只指定名称
props: [‘name’, ‘age’, ‘setName’]
-
读取方式二: 指定名称和类型
props: { name: String,
age: Number,
setNmae: Function
}
-
读取方式三: 指定名称/类型/必要性/默认值
props: { name: {type: String, required: true, default:xxx},
}
3.3 混入
-
Vue 插件是一个包含 install 方法的对象
-
通过 install 方法给 Vue 或 Vue 实例添加方法, 定义全局指令等
3.4 插件
-
Vue 插件是一个包含 install 方法的对象
-
通过 install 方法给 Vue 或 Vue 实例添加方法, 定义全局指令等
组件化编码流程(通用)
1.实现静态组件:抽取组件,使用组件实现静态页面效果
2.展示动态数据:
2.1. 数据的类型、名称是什么?
2.2. 数据保存在哪个组件?
3.交互——从绑定事件监听开始
3.6 Vue 中的自定义事件 绑定事件监听
<Header @addTodo="addTodo"/>
或者
<Header ref="header"/>
this.$refs.header.$on('addTodo',this.addTodo)
触发事件
this.$emit('addTodo',todo)
3.7 全局事件总线
3.7.1 理解
-
Vue 原型对象上包含事件处理的方法
-
/1) $on(eventName, listener): 绑定自定义事件监听
-
/2) $emit(eventName, data): 分发自定义事件
-
/3) $off(eventName): 解绑自定义事件监听
-
/4) $once(eventName, listener): 绑定事件监听, 但只能处理一次
-
-
所有组件实例对象的原型对象的原型对象就是 Vue 的原型对象
-
/1) 所有组件对象都能看到 Vue 原型对象上的属性和方法
-
/2) Vue.prototype.$bus = new Vue(), 所有的组件对象都能看到$bus 这个属性 对象
-
全局事件总线 /1) 包含事件处理相关方法的对象(只有一个) 2) 所有的组件都可以得到
3.7.2 指定事件总线对象
new Vue({
beforeCreate () { // 尽量早的执行挂载全局事件总线对象的操作
Vue.prototype.$globalEventBus = this
},
}).$mount('#root')
3.7.3 绑定事件
this.$globalEventBus.$on('deleteTodo', this.deleteTodo)
3.7.4 分发事件
this.$globalEventBus.$emit('deleteTodo', this.index)
3.7.5 解绑事件
this.$globalEventBus.$off('deleteTodo')
3.8 消息订阅与发布 3.8.1 理解
-
这种方式的思想与全局事件总线很相似
-
它包含以下操作:
(1) 订阅消息–对应绑定事件监听
(2) 发布消息–分发事件 (3) 取消消息订阅–解绑事件监听
-
需要引入一个消息订阅与发布的第三方实现库: PubSubJS 3.8.2 使用 PubSubJS
-
下载: npm install -S pubsub-js
-
相关语法
-
(1) import PubSub from ‘pubsub-js’ // 引入 (2) PubSub.subscribe(‘msgName’,functon(msgName,data){}) (3) PubSub.publish(‘msgName’,data):发布消息,触发订阅的回调函数调用 (4) PubSub.unsubscribe(token):取消消息的订阅
3.9 过度与动画
3.9.2 vue 动画的理解
-
操作 css 的 trasition 或 animation
-
vue 会给目标元素添加/移除特定的 class
-
过渡的相关类名:
-
xxx-enter-active: 指定显示的 transition
-
xxx-leave-active: 指定隐藏的 transition
-
xxx-enter/xxx-leave-to: 指定隐藏
-
3.9.3 基本过渡动画的编码
-
在目标元素外包裹<transition name=”xxx”>
-
定义 class 样式
-
a) 指定过渡样式: transition
-
b) 指定隐藏时的样式: opacity/其它
-
第 4 章:Vue 中的 ajax
4.1 解决开发环境 Ajax 跨域问题
使用代理服务器
4.2 github 接口地址
https://api.github.com/search/users?q=xxx
4.3 vue 项目中常用的 2 个 Ajax 库 4.3.1 axios
通用的 Ajax 请求库, 官方推荐,使用广泛
4.3.2 vue-resource
vue 插件库, vue1.x 使用广泛,官方已不维护。
4.4 slot 插槽
4.4.1 理解
父组件向子组件传递带数据的标签,当一个组件有不确定的结构时, 就需要使用 slot 技术,注意:插槽内容是在父组件中编译后, 再传递给子组件的。
4.4.2 分类
-
默认插槽 2. 命名插槽 3. 作用域插槽
第 5 章:vuex
5.1 理解 vuex
5.1.1 vuex 是什么
-
概念:专门在 Vue 中实现集中式状态(数据)管理的一个 Vue 插件,对 vue 应 用中多个组件的共享状态进行集中式的管理(读/写),也是一种组件间通信的方 式,且适用于任意组件间通信。
-
Github 地址: https://github.com/vuejs/vuex
5.1.2 什么时候使用 Vuex
/1. 多个组件依赖于同一状态 /2. 来自不同组件的行为需要变更同一状态
5.1.4 Vuex 工作原理图
5.2 vuex 核心概念和 API
5.2.1 state
-
vuex 管理的状态对象
-
它应该是唯一的
-
示例代码:
const state = {
xxx: initValue
}
5.2.2 actions
/1. 值为一个对象,包含多个响应用户动作的回调函数 /2. 通过 commit( )来触发 mutation 中函数的调用, 间接更新 state
/3. 如何触发 actions 中的回调?
在组件中使用: $store.dispatch('对应的 action 回调名') 触发
/4. 可以包含异步代码(定时器, ajax 等等)
/5. 示例代码:
const actions = {
zzz({commit,state},data1){
commit('yyy',{data1})
}
}
5.2.3 mutations
-
值是一个对象,包含多个直接更新 state 的方法
-
谁能调用 mutations 中的方法?如何调用?在 action 中使用:commit**(‘对应的** mutations 方法名**’)** 触发
-
mutations 中方法的特点:不能写异步代码、只能单纯的操作 state
-
示例代码:
const mutations = {
yyy (state,{data1}){
//更新state的某个属性
}
}
5.2.4 getters
-
值为一个对象,包含多个用于返回数据的函数
-
如何使用?—— $store**.getters.xxx
-
示例代码:
const getters={
mmm(state){
return state.msg + '!'
}
}
5.2.5 modules
/1. 包含多个 module /2. 一个 module 是一个 store 的配置对象 3. 与一个组件(包含有共享数据)对应
第 6 章:**vue-router**
6.1 相关理解
6.1.1 vue-router 的理解
vue 的一个插件库,专门用来实现SPA应用
6.1.2 对 SPA 应用的理解
/1. 单页 Web 应用(single page web application,SPA)。 /2. 整个应用只有一个完整的页面。 /3. 点击页面中的导航链接不会刷新页面,只会做页面的局部更新。 4. 数据需要通过 ajax 请求获取。
6.1.3 路由的理解
1. 什么是路由?
-
一个路由就是一组映射关系(key – value)
-
key 为路径, value 可能是 function 或 component
2. 路由分类
-
后端路由:
-
理解:value 是 function, 用于处理客户端提交的请求。
-
工作过程:服务器接收到一个请求时, 根据请求路径找到匹配的函数 来处理请求, 返回响应数据。
-
-
前端路由:
-
理解:value 是 component,用于展示页面内容。
-
工作过程:当浏览器的路径改变时, 对应的组件就会显示
6.2.2 总结: 编写使用路由的 3 步
-
定义路由组件
-
注册路由
-
使用路由
6.3 嵌套(多级)路由
6.4 路由传参
6.5 编程式路由导航
相关 API:
-
this.$router.push(path): 相当于点击路由链接(可以返回到当前路由界面)
-
this.$router.replace(path): 用新路由替换当前路由(不可以返回到当前路由界面)
-
this.$router.back(): 请求(返回)上一个记录路由
-
this.$router.go(-1): 请求(返回)上一个记录路由
-
this.$router.go(1): 请求下一个记录路由
第 7 章:Vue UI 组件库
7.1 移动端常用 UI 组件库
-
Cube UI https://didi.github.io/cube-ui
-
Mint UI http://mint-ui.github.io
7.2 PC 端常用 UI 组件库
-
Element UI https://element.eleme.cn
-
IView UI https://www.iviewui.com
原创文章,作者:carmelaweatherly,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/273315.html