Vue 脚手架


3 章:使用 Vue 脚手架

3.1 初始化脚手架

3.1.1 说明

  1. Vue 脚手架是 Vue 官方提供的标准化开发工具(开发平台)。

  2. 最新的版本是 4.x。

  3. 文档: https://cli.vuejs.org/zh/

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

  1. 作用:用于父组件给子组件传递数据

  1. 读取方式一: 只指定名称

    props: [‘name’, ‘age’, ‘setName’]

  2. 读取方式二: 指定名称和类型

    props: { name: String,

    age: Number,

    setNmae: Function

    }

  3. 读取方式三: 指定名称/类型/必要性/默认值

    props: { name: {type: String, required: true, default:xxx},

    }

3.3 混入

  1. Vue 插件是一个包含 install 方法的对象

  1. 通过 install 方法给 Vue 或 Vue 实例添加方法, 定义全局指令等

3.4 插件

  1. Vue 插件是一个包含 install 方法的对象

  2. 通过 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 理解

  1. Vue 原型对象上包含事件处理的方法

    1. /1) $on(eventName, listener): 绑定自定义事件监听

    2. /2) $emit(eventName, data): 分发自定义事件

    3. /3) $off(eventName): 解绑自定义事件监听

    4. /4) $once(eventName, listener): 绑定事件监听, 但只能处理一次

  2. 所有组件实例对象的原型对象的原型对象就是 Vue 的原型对象

  1. /1) 所有组件对象都能看到 Vue 原型对象上的属性和方法

  2. /2) Vue.prototype.$bus = new Vue(), 所有的组件对象都能看到$bus 这个属性 对象

  1. 全局事件总线 /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. 这种方式的思想与全局事件总线很相似

  1. 它包含以下操作:

(1) 订阅消息–对应绑定事件监听

(2) 发布消息–分发事件 (3) 取消消息订阅–解绑事件监听

  1. 需要引入一个消息订阅与发布的第三方实现库: PubSubJS 3.8.2 使用 PubSubJS

    1. 在线文档: https://github.com/mroderick/PubSubJS

    1. 下载: npm install -S pubsub-js

    1. 相关语法

(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 动画的理解

  1. 操作 css 的 trasition 或 animation

  1. vue 会给目标元素添加/移除特定的 class

  1. 过渡的相关类名:

    1. xxx-enter-active: 指定显示的 transition

    2. xxx-leave-active: 指定隐藏的 transition

    3. xxx-enter/xxx-leave-to: 指定隐藏

    Vue 脚手架

 

 

3.9.3 基本过渡动画的编码

  1. 在目标元素外包裹<transition name=”xxx”>

  2. 定义 class 样式

    1. a) 指定过渡样式: transition

    2. 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 分类

  1. 默认插槽 2. 命名插槽 3. 作用域插槽

第 5 章:vuex

5.1 理解 vuex

5.1.1 vuex 是什么

  1. 概念:专门在 Vue 中实现集中式状态(数据)管理的一个 Vue 插件,对 vue 应 用中多个组件的共享状态进行集中式的管理(读/写),也是一种组件间通信的方 式,且适用于任意组件间通信。

  2. Github 地址: https://github.com/vuejs/vuex

5.1.2 什么时候使用 Vuex

/1. 多个组件依赖于同一状态 /2. 来自不同组件的行为需要变更同一状态

5.1.4 Vuex 工作原理图

Vue 脚手架

 

 

5.2 vuex 核心概念和 API

5.2.1 state

  1. vuex 管理的状态对象

  2. 它应该是唯一的

  3. 示例代码:

    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

  1. 值是一个对象,包含多个直接更新 state 的方法

  1. 谁能调用 mutations 中的方法?如何调用?在 action 中使用:commit**(‘对应的** mutations 方法名**’)** 触发

  1. mutations 中方法的特点:不能写异步代码、只能单纯的操作 state

  2. 示例代码:

const mutations = {
 yyy (state,{data1}){
   //更新state的某个属性
}
}

5.2.4 getters

  1. 值为一个对象,包含多个用于返回数据的函数

  1. 如何使用?—— $store**.getters.xxx

  2. 示例代码:

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. 什么是路由?

  1. 一个路由就是一组映射关系(key – value)

  2. key 为路径, value 可能是 function 或 component

2. 路由分类

  1. 后端路由:

    1. 理解:value 是 function, 用于处理客户端提交的请求。

    1. 工作过程:服务器接收到一个请求时, 根据请求路径找到匹配的函数 来处理请求, 返回响应数据。

  1. 前端路由:

  1. 理解:value 是 component,用于展示页面内容。

  1. 工作过程:当浏览器的路径改变时, 对应的组件就会显示

6.2.2 总结: 编写使用路由的 3 步

  1. 定义路由组件

  1. 注册路由

  1. 使用路由

6.3 嵌套(多级)路由

6.4 路由传参

6.5 编程式路由导航

相关 API:

  1. this.$router.push(path): 相当于点击路由链接(可以返回到当前路由界面)

  2. this.$router.replace(path): 用新路由替换当前路由(不可以返回到当前路由界面)

  3. this.$router.back(): 请求(返回)上一个记录路由

  4. this.$router.go(-1): 请求(返回)上一个记录路由

  5. this.$router.go(1): 请求下一个记录路由

第 7 章:Vue UI 组件库

7.1 移动端常用 UI 组件库

  1. Vant https://youzan.github.io/vant

  2. Cube UI https://didi.github.io/cube-ui

  3. Mint UI http://mint-ui.github.io

7.2 PC 端常用 UI 组件库

  1. Element UI https://element.eleme.cn

  1. IView UI https://www.iviewui.com

原创文章,作者:carmelaweatherly,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/273315.html

(0)
上一篇 2022年7月10日 05:19
下一篇 2022年7月10日 05:19

相关推荐

发表回复

登录后才能评论