vue-learning:0 - 目录
Vue-learning
vue.js学习路径

Vue的API地图
视图层
点击可直接到达详情页面
指令
样式
特殊特性
过渡动画
模板形式
逻辑层
通用配置选项option
生命周期钩子函数
beforeCreatecreatedbeforeMountmountedbeforeUpdateupdatedbeforeDestorydestoryactivated(keep-alive)deactivated(keep-alive)
组件 Component
组件的概念
组件的构建和注册
- 构建:
com = Vue.extend(option) - 注册:
Vue.component('my-com', com)/vm.components: {'my-com': com} - 语法糖:
Vue.component('my-com',option)vm.components('my-com': option) - 组件命名规范
- 构建:
组件三大API:
prop/event/slot
prop- 字符串数组形式:
props: ['prop1', 'prop2', ...] - 对象形式:
type / required / defalut / validator - prop的命名规范
- 动态prop(除字符串外,其它类型传入都需要使用动态prop,即v-bind绑定)
- 单向数据流
- 非prop特性:
inheritAttr: false; / $attrs
event
v-on / $on监听事件$once一次性事件$emit触发事件$off卸载事件监听$listenersv-on绑定监听器集合(除原生监听事件).native原生事件修饰符.sync双向绑定修饰符model属性
slot
- 普通插槽
<slot></slot>
- 插槽提供默认值
<slot>default content</slot>
- 具名插槽
<slot name="someName"></slot>
<!-- 组件调用 -->
<my-com>
<template v-slot:somName></template>
<my-com>
- 作用域插槽
<slot :prop="value"></slot>
<!--组件调用 -->
<my-com>
<template v-slot='childValue'>{{ cilidValue.value}}</template>
</my-com>
- 独占默认插槽的写法
<some-component v-slot="childValue"> {{ childValue.value }}</some-component>
<some-component v-slot:default="childValue"> {{ childValue.value }}</some-component>
- 解构插槽prop
<my-com v-slot="{value}">{{ value }}</my-com>
<!-- 重命名 -->
<my-com v-slot="{value: otherName}">{{ otherName }}</my-com>
<!-- 重命名并提供默认值 -->
<my-com v-slot="{value: {otherName: defaultValue}}">{{ otherName }}</my-com>
- 动态插槽名
<my-com>
<template v-slot:[dynamicSlotName]></template>
</my-com>
v-slot的简写#<my-com>
<template #:somName></template>
<my-com>
- 模板编译作用域 和 插槽作用域
- 字符串数组形式:
组件实例的调用
ref$root$parent$children
组件间的通信
- 父子组件通信
prop / $emit - 三层嵌套组件
$attrs/$liteners - 后代组件通信
provide / inject - 组件实例引用
$root/$parent/$children/$refs - 事件总线
const Bus = new Vue() - 状态管理器
Vuex
- 父子组件通信
动态组件
is异步组件
工厂函数函数式组件
functional内置组件
transiton/keep-alive其它
- 组件的递归调用
- 组件的循环引用
v-once创建静态组件
路由 Vue-router
- 前端路由历史
- 服务端渲染(SSR:server side render)
- 客户端路由(client side routing)
- 前端路由实现原理
- hash模式: location.hash 和 hashChange事件
- history模式: history 和 popstate事件
- vue-router
- const router = new VueRouter(option)中的选项对象option
- 路由器实例对象router
- 路由对象route
- router-link标签的特性
- router-view标签的特性
- 路由传参的5种方式
1.路由动态参数: '/user/:userId'和paramsconst route = {path: '/user/:userId'}
this.$router.push({path:`/user/${userId}`})
this.$route.params.userId
2.命名路由传参,使用name和params
const route = {name:'home',...}
this.$router.push({name:'Login',params:{id:'leelei'}})
this.$route.params.id
3.查询参数传参,使用path和query
this.$router.push({path:'/login',query:{id:'leelei'})
this.$route.query.id
4.prop形式:布尔/对象/函数
const route = [{prop:true, ...}]
const route = [{prop: {someProp:'someValue'}]
const routes =[{props: (route) => ({ query: route.query.q }),...}]
- meta元信息定义数据
// 定义路由时,定义元信息
const routes = [
{meta: {someData:'someData'},... },
// 获取数据
this.$route.meta.someData
- 从路由中获取组件实例
const matchedComponents: Array<Component> = this.$router.getMatchedComponents(location?)
状态管理 Vuex
- 状态管理的概念
- vuex基本使用
- Vuex对象
- option选项
- store实例对象的属性: state, getters
- store实例对象的方法
- commit / dispatch
- 注册和卸载plugin的方法
- 注册和卸载Module的方法
- vuex的辅助函数: mapState / mapGetters / mapMutaions / mapActions
- vuex的项目结构组织
单元测试 vue-test-utils
项目构建vue-cli
进阶内容
- 响应式原理
- 虚拟DOM
- 模板编译原理
Vue API和vm API
vue-learning:0 - 目录的更多相关文章
- Vue 2.0 + Vue Router + Vuex
用 Vue.js 2.x 与相配套的 Vue Router.Vuex 搭建了一个最基本的后台管理系统的骨架. 当然先要安装 node.js(包括了 npm).vue-cli 项目结构如图所示: ass ...
- vue(2.0)+vue-router(2.0)+vuex(2.0)实战
好久没更新自己的知识库,刚好借双十一的契机,用上了vue(2.0)+vue-router(2.0)+vuex(2.0)来开发公司的双十一电商活动. 项目目录结构: 运行: npm install np ...
- vue 3.0 体验,vue 3.0新特性
前言 昨天不是尤雨溪 不是刚在B站 直播玩了,分享了vue-next v3.0.0-beta.1 版本 哈哈, 不要太刺激哦 6大亮点 Performance:性能更比Vue 2.0强. Tree s ...
- 重磅来袭 Vue 3.0 One Piece 正式发布
代号为One Piece 的Vue3.0 在9月19日凌晨正式发布!! 此次vue3.0 为用户提供了全新的 composition-api 以及更小的包大小,和更好的 TypeScript 支持. ...
- 使用 Vue 2.0 实现服务端渲染的 HackerNews
Vue 2.0 支持服务端渲染 (SSR),并且是流式的,可以做组件级的缓存,这使得极速渲染成为可能.同时, 和 2.0 也都能够配合 SSR 提供同构路由和客户端 state hydration.v ...
- 新手入门指导:Vue 2.0 的建议学习顺序
起步 1. 扎实的 JavaScript / HTML / CSS 基本功.这是前置条件. 2. 通读官方教程 (guide) 的基础篇.不要用任何构建工具,就只用最简单的 <script> ...
- vue 2.0 无法编译ES6语法
# vue2.0 webpack 无法编译 ES6 语法 之前在使用 vue 1.x 时用 vue-loader@8.0.0 版本可以正常打包vue的代码,包括ES6语法也能正常转为ES5语法,但是当 ...
- Vue 2.0初学后个人总结及分享
摘要:最近在上海找工作,发现Vue前景还不错,于是就打算先学习一下(之前了解过,但是一直没提到日程上)这篇随笔当是为了自己学习之后,做一个小的阶段性总结.希望本文的内容对于刚开始接触vue的朋友们有点 ...
- Arcade初探[0] 目录与导航
2017年6月,ESRI开发者页面出现了一个新玩意儿:Arcade. 连接:点我 这是什么东西呢?有什么用呢? 1. 是什么 Arcade一种表达语言,可以在ArcGIS平台上使用.不管是编写简单的脚 ...
- 《vue.js2.0从入门到放弃》学习之路
原文地址: Vue.js2.0从入门到放弃---入门实例(一):http://blog.csdn.net/u013182762/article/details/53021374 Vue.js2.0从入 ...
随机推荐
- 了解apache与tomcat的关系
较多的了解过apache,但对tomcat却了解不多: 使用LAMP构建网站毕竟还是有很大局限,越来越多的网站将给予java构建了. http://developer.51cto.com/art/20 ...
- OFBiz 16.11.03的直接部署、eclipse部署和IDEA部署
一.在OFBiz官网下载最新的发行版本,也就是16.11.03版本. 下载地址:http://ofbiz.apache.org/download.html 点击页面Apache OFBiz 16. ...
- python 正则表达式简介
- 一条SQL完成跨数据库实例Join查询
背景 随着业务复杂程度的提高.数据规模的增长,越来越多的公司选择对其在线业务数据库进行垂直或水平拆分,甚至选择不同的数据库类型以满足其业务需求.原本在同一数据库实例里就能实现的SQL查询,现在需要跨多 ...
- HDU 4193
本题思路:用sum[]数组维护前缀和, 当然这里需要把原数组扩大为原来的两倍. 然后对于任意一个长度为n的区间 k.....k+n-1,如果有该区间内的最小值大于等于sum[k-1]那么该种情况就符合 ...
- Hbuilder的使用技巧
/*注:本教程针对HBuilder5.0.0,制作日期2014-12-31*/创建HTML结构: h 8 (敲h激活代码块列表,按8选择第8个项目,即HTML代码块,或者敲h t Enter)中途换行 ...
- Mysterious Antiques in Sackler Museum(判断长方形)
题目链接 参考博客Ritchie丶的博客 - UVALive 7267 Mysterious Antiques in Sackler Museum (判断长方形) 题意:大概意思就是判断四个矩形能不能 ...
- 十年磨一剑,王坚自研的MaxCompute如何解决世界级算力难题
摘要: 2009年这项关于大数据的技术长征开始.王坚带队,目标是自研大数据计算平台MaxCompute统一阿里巴巴内部的数据和大数据计算体系. 大数据时代,随着企业数据规模的急剧增长,传统软件已无法承 ...
- jQuery 五角星评分
五角星打分 我用的是搜狗输入法上带的特殊符号打出来的 空五角星:☆ 实五角星:★ 1.html <ul class="comment"> <li>☆&l ...
- selenium 图片上传
WebElement file = driver.findElement(By.name("filename")); 给此元素设置值:file.sendKeys("E: ...