1.自定义指令
a.自定义指令:
自己定义的指令,可以封装一些dom 操作,扩展额外功能
data:image/s3,"s3://crabby-images/c7850/c7850d1492172ab5953b5825881f0caadd9868b9" alt=""
data:image/s3,"s3://crabby-images/8d137/8d13723bffa5baea31d52e0bd0dfc7c60dd9d440" alt=""
全局注册:
data:image/s3,"s3://crabby-images/ec522/ec5224acf2382708b39d531a319a70d505f1ee93" alt=""
局部注册:
data:image/s3,"s3://crabby-images/c1cc6/c1cc6df3236fb9879e69a610e450f4cdab58d8cd" alt=""
指令值:自定义指令
data:image/s3,"s3://crabby-images/b45c1/b45c1d080d4c4e6f7b7334a0206c8aebdab62bbc" alt=""
data:image/s3,"s3://crabby-images/170d0/170d08352d2b57d3dfab844bb6639c704b71f5f5" alt=""
v-loading:
本质:
data:image/s3,"s3://crabby-images/fa167/fa167648110eae91896c67da6dde195a4f141d50" alt=""
插槽:
1.定制插槽
data:image/s3,"s3://crabby-images/1c5b9/1c5b929175c2556c15432b687b95a05848a3c8ec" alt=""
2.插槽作用
data:image/s3,"s3://crabby-images/95e19/95e19a490dfcef173f931d6ae04e20acdaef9b24" alt=""
data:image/s3,"s3://crabby-images/d1eec/d1eec9874d6a7297a1cab0c47dc2548383f55378" alt=""
data:image/s3,"s3://crabby-images/4f674/4f674d2311c2b58a5163c110c682c7700e216cac" alt=""
组件封装:涵盖了以上所有的知识点
1.失去焦点 : @blur=" 判定条件 "
2.得到当前动作的值: e.target.value
代码:在插槽拼接
路由:
data:image/s3,"s3://crabby-images/94a3c/94a3ce63793ea90d5458b61fbe08754331ca6474" alt=""
data:image/s3,"s3://crabby-images/c155a/c155ab11dfe9683a46a28c2fecc8790f02dc3ff2" alt=""
使用步骤:(5+2)
data:image/s3,"s3://crabby-images/28e25/28e2501d1978c3788d5362ba6341245cee834da5" alt=""
实现:
data:image/s3,"s3://crabby-images/75768/75768c08543b92a33465b877026b3eb2f7503227" alt=""
data:image/s3,"s3://crabby-images/60c9f/60c9f65522a6e050e1027b778b0c030108143fce" alt=""
这里很奇怪,为什么组件要有如下配置
data:image/s3,"s3://crabby-images/88a4f/88a4f6fb5f610ded9c804b0851b28de7e5abc3e3" alt=""
使用总结:
data:image/s3,"s3://crabby-images/2fca5/2fca572824158e5b589d06e91ea88acf6e1518f6" alt=""
路由和组件分类:
data:image/s3,"s3://crabby-images/cf45a/cf45a4b151851f50f06eb30a8e0217234adb62f3" alt=""
代码:
import Vue from 'vue'
import App from './App.vue'
// 路由的使用步骤 5 + 2
// 5个基础步骤
// 1. 下载 v3.6.5
// 2. 引入
// 3. 安装注册 Vue.use(Vue插件)
// 4. 创建路由对象
// 5. 注入到new Vue中,建立关联
// 2个核心步骤
// 1. 建组件(views目录),配规则
// 2. 准备导航链接,配置路由出口(匹配的组件展示的位置)
import Find from './views/Find'
import My from './views/My'
import Friend from './views/Friend'
import VueRouter from 'vue-router'
Vue.use(VueRouter) // VueRouter插件初始化
const router = new VueRouter({
// routes 路由规则们
// route 一条路由规则 { path: 路径, component: 组件 }
routes: [
{ path: '/find', component: Find },
{ path: '/my', component: My },
{ path: '/friend', component: Friend },
]
})
Vue.config.productionTip = false
new Vue({
render: h => h(App),
router:router,
}).$mount('#app')
<template>
<div>
<div class="footer_wrap">
<a href="#/find">发现音乐</a>
<a href="#/my">我的音乐</a>
<a href="#/friend">朋友</a>
</div>
<div class="top">
<!-- 这个是路由内容展现所在的位置,用router-view -->
<router-view></router-view>
</div>
</div>
</template>
<script>
export default {};
</script>
<template>
<div>
<p>我的音乐</p>
<p>我的音乐</p>
<p>我的音乐</p>
<p>我的音乐</p>
</div>
</template>
<script>
export default {
name: 'MyMusic'
}
</script>