目录
v-on
v-on阻止事件冒泡
监听键盘事件
v-once
v-if v-else v-show
v-if
v-else
v-for
v-for遍历数组
v-for遍历对象?
?splice()
?点击切换颜色
?v-model
?v-model结合radio使用
v-model结合checkbox
单选框
?
input中的值绑定
?v-model修饰符
?组件
注册组件的基本步骤
注册组件的语法糖?
模板分离写法
??
父子组件通信?
子传父(自定义事件)子组件产生了事件,希望父组件知道
?父组件访问子组件
?子组件访问父组件
?插槽
?具名插槽
?编译作用域
?安装使用路由
?路由跳转的两种方式
router-link补充
?
路由重定向,模式
动态路由
路由懒加载
?嵌套路由
?传递参数
?导航守卫
?keep-alive
?判断路由是否处于活跃状态的方法
?给文件路径配置别名
?vuex
?通过mutation来修改state
mutations 携带参数
?mutation响应规则
?getter基本使用
?action使用
?vuex-module
?vuex目录结构
?vuex运用173p
v-on
1.v-on在绑定事件的时候如果事件不需要传参,可以省略(),data:image/s3,"s3://crabby-images/c3065/c3065b7408f17d50bc18b53fd0daeecf592cd34b" alt=""
2.这个时候系统会默认给绑定的事件传event参数,这时候如果想获取到event对象,也可以加()
data:image/s3,"s3://crabby-images/c301a/c301ac7bbcc69a626946abc0336a83c89b38dd8e" alt=""
3.如果需要传递参数的时候,绑定事件的时候就必须要加(),并传入参数
data:image/s3,"s3://crabby-images/6e418/6e418708e933625dcc4f78c7d5c1c7ee7632c168" alt="" data:image/s3,"s3://crabby-images/c706d/c706d96ff29eb4b8b4edebb0eb6be29d36fc9729" alt=""
?4.如果自己又要传入参数,但是用想拿到默认的event参数怎么办
传入参数的时候event必须要加上$符号
data:image/s3,"s3://crabby-images/cb239/cb2398353637f9d669a5ff0817df48bd01072578" alt=""
?data:image/s3,"s3://crabby-images/a2c2c/a2c2ce5f4fcb89cecf36fd8a7c23f22547ed20ae" alt=""
v-on阻止事件冒泡
@click.stop
data:image/s3,"s3://crabby-images/e38d3/e38d325be8b5343fecb80a13d3cdc994824511c5" alt=""
data:image/s3,"s3://crabby-images/da9e1/da9e15bf0657dd60757dc2fd1b1740f79d62ac40" alt=""
监听键盘事件
data:image/s3,"s3://crabby-images/4a456/4a456076707152318825b5db562a572c838a4db6" alt=""
data:image/s3,"s3://crabby-images/c55db/c55db1682ac319dd772e31f312648d01f7e3c2d4" alt=""
?只监听输入回车
data:image/s3,"s3://crabby-images/04dca/04dcac609e0a64afd85db4e36bb2cc0c7b7315da" alt=""
v-once
只会触发一次函数
data:image/s3,"s3://crabby-images/31253/31253f4a64bc42449c243d8aefbb7def08d78780" alt=""
v-if v-else v-show
v-if
data:image/s3,"s3://crabby-images/f74c7/f74c75eef1e4dbcfb91eba24a677936d83a835ff" alt=""
v-else
data:image/s3,"s3://crabby-images/8caa1/8caa120eb3f2fc7354e80021885babc52180b703" alt=""
data:image/s3,"s3://crabby-images/54c1d/54c1de6c883b7594cc0605c66a445e4e32429203" alt=""
v-for
v-for遍历数组
没有用到索引下标
data:image/s3,"s3://crabby-images/eedd4/eedd4e3a00c6588669147a8b6850df5497166043" alt=""
?用到了索引下标
data:image/s3,"s3://crabby-images/d88ab/d88ab7128b31bd8df4437f428a90770963278cad" alt=""
v-for遍历对象?
1.遍历对象如果只有一个值,那么获得的是value
data:image/s3,"s3://crabby-images/7b545/7b5453f6d9418d56f1914f98cc7a5e2da3722a6e" alt=""
?2.如果想获取key和value
data:image/s3,"s3://crabby-images/a0962/a09620093ceb9a5176098f0ef36b40e90edd228d" alt=""
?3.还可以获取index
data:image/s3,"s3://crabby-images/1f300/1f30041143e3ffee702f727a6e812c2ab91978e0" alt=""
?splice()
data:image/s3,"s3://crabby-images/c6554/c6554fca89ab357ea6f92c51b8bb2c271cb7dba8" alt=""
?点击切换颜色
<style>
.active {
color: red;
}
</style>
<template>
<div class="about">
<ul>
<li
v-for="(item, index) in movies"
:key="item"
@click="changeColor(index)"
:class="{ active: current === index }"
>
{{ item }}
</li>
</ul>
</div>
</template>
<script>
export default {
data() {
return {
movies: ["海贼王", "火影忍者", "名侦探柯南"],
current: 0,
};
},
methods: {
changeColor(index) {
this.current = index;
},
},
};
</script>
?v-model
data:image/s3,"s3://crabby-images/216d3/216d3c04eed07674088bf23b9fee9a7bcc27a85a" alt=""
?v-model结合radio使用
data:image/s3,"s3://crabby-images/07451/074515929b215f143f589eee5aa9404daaa026d6" alt=""
v-model结合checkbox
单选框
data:image/s3,"s3://crabby-images/dfe7d/dfe7ded0a7ae8d371f3d42518542fe85ebf64591" alt=""
多选框
data:image/s3,"s3://crabby-images/c636c/c636c27f1bb9fccfcb4e81b25ce1c6f62795964d" alt=""
?data:image/s3,"s3://crabby-images/0f23f/0f23f10bb53f6cf045b62fec9510d9ca23cdef54" alt=""
?加?multiple可以多选
data:image/s3,"s3://crabby-images/c9976/c9976a8532b4b61fc6ebc753a52094794d35ca57" alt=""
?v-model修饰符
data:image/s3,"s3://crabby-images/63fa3/63fa37f4c9030f27d880f1e4579c15838ea0c0e0" alt=""
1. lazy修饰符
data:image/s3,"s3://crabby-images/ff065/ff065fad0068b434a91f94ee3b72da8d6b7763b6" alt=""
2. number修饰符
data:image/s3,"s3://crabby-images/1ad28/1ad28746700bc89fd922a2399414d4494a3f69e2" alt=""
?3.trim修饰符
data:image/s3,"s3://crabby-images/1a568/1a5685df76b218b0cc9e285e8ef7d2e857ffa7d4" alt=""
?组件
注册组件的基本步骤
data:image/s3,"s3://crabby-images/2025f/2025f31378daded372c3c045f316cfddd1fd7c84" alt=""
?注册子组件
data:image/s3,"s3://crabby-images/e7df2/e7df2d5a5378fd2ea26d68175d1f2b0b872a8a41" alt=""
注册组件的语法糖?
注册全局组件语法糖
data:image/s3,"s3://crabby-images/48328/48328dfc70b0724ffe85dffb8f837fda8e8d164c" alt=""
?注册局部组件语法糖
data:image/s3,"s3://crabby-images/9559b/9559b4b0cd1dd031d710eb7679033245f24f3dc6" alt=""
模板分离写法
?data:image/s3,"s3://crabby-images/7f1a4/7f1a4137094a582076d894012bc25ce1864ec863" alt=""
?data:image/s3,"s3://crabby-images/5e01f/5e01ff1542cddf0ffb343c9c1e2e571a8e0d77aa" alt=""
父子组件通信?
data:image/s3,"s3://crabby-images/9a476/9a476c544a1ea6f49bb1ab3b97ee83eec56dffd0" alt=""
?父组件通过props向子组件传递数据
data:image/s3,"s3://crabby-images/4b9c4/4b9c4652fdb3bb79a9b5132a5d29d1f7927a5d6f" alt=""
?props写成数组字符串的形式很别扭,可以加类型限制和提供默认值data:image/s3,"s3://crabby-images/381bf/381bf34ed4a8f51eba220c9b8653cc2681773640" alt=""
子传父(自定义事件)子组件产生了事件,希望父组件知道
data:image/s3,"s3://crabby-images/a694d/a694d4d5ac9cb9f2a7f8f44ec2909eda06381e96" alt=""
?子组件监听事件data:image/s3,"s3://crabby-images/251e2/251e2f0114d13e131582fe4ce4585ea82e3b3684" alt=""
子组件发射事件
data:image/s3,"s3://crabby-images/430af/430afa8550e08a627e0bce4ac5cbfa53163d29dd" alt=""
data:image/s3,"s3://crabby-images/8f6bf/8f6bf3ba1a234c1cf50e0f34e6cf17f667dde0fc" alt=""
?父组件监听子组件发射的事件触发父组件中的cpnClick事件data:image/s3,"s3://crabby-images/95ba7/95ba7a2e6e1797c28a225663343f43014526fdbd" alt=""
?data:image/s3,"s3://crabby-images/3e610/3e61057c343b3ee1c961d7d1aea832b3df6dd3d4" alt=""
?这里的item如果在上一步传递的时候@itemClick=‘cpnclick(没有传过来item)’,系统会默认传递item,就像之前会默认传递event一样
?父组件访问子组件
$children(一般不用这种方式访问子组件,一般用$refs来拿)
data:image/s3,"s3://crabby-images/3cd52/3cd5255a6d6acfb9a6eff8a999843260be00101d" alt=""
data:image/s3,"s3://crabby-images/6cb41/6cb4195abfacf60ab8b35e6d9b2ddd7cd26c6564" alt=""
?通过refs访问子组件
data:image/s3,"s3://crabby-images/498f6/498f609cc71d10ff88a62b4df025874bf32c20f5" alt=""
?data:image/s3,"s3://crabby-images/7fb26/7fb26107a42baa8c0a6d4314bb16995b504262c6" alt=""
?子组件访问父组件
$parent(开发过程中不建议使用)
$root访问根组件
?插槽
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<!--
1.插槽的基本使用 <slot></slot>
2.插槽的默认值 <slot>button</slot>
3.如果有多个值, 同时放入到组件进行替换时, 一起作为替换元素
-->
<div id="app">
<cpn></cpn>
<cpn><span>哈哈哈</span></cpn>
<cpn><i>呵呵呵</i></cpn>
<cpn>
<i>呵呵呵</i>
<div>我是div元素</div>
<p>我是p元素</p>
</cpn>
<cpn></cpn>
<cpn></cpn>
<cpn></cpn>
<cpn></cpn>
</div>
<template id="cpn">
<div>
<h2>我是组件</h2>
<p>我是组件, 哈哈哈</p>
<slot><button>按钮</button></slot>
<!--<button>按钮</button>-->
</div>
</template>
<script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: '你好啊'
},
components: {
cpn: {
template: '#cpn'
}
}
})
</script>
</body>
</html>
?具名插槽
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<cpn><span slot="center">标题</span></cpn>
<cpn><button slot="left">返回</button></cpn>
</div>
<template id="cpn">
<div>
<slot name="left"><span>左边</span></slot>
<slot name="center"><span>中间</span></slot>
<slot name="right"><span>右边</span></slot>
</div>
</template>
<script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: '你好啊'
},
components: {
cpn: {
template: '#cpn'
}
}
})
</script>
</body>
</html>
?编译作用域
?isShow会用实例中的isShow,而不是cpn组件中的isShow
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<cpn v-show="isShow"></cpn>
<cpn v-for="item in names"></cpn>
</div>
<template id="cpn">
<div>
<h2>我是子组件</h2>
<p>我是内容, 哈哈哈</p>
<button v-show="isShow">按钮</button>
</div>
</template>
<script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: '你好啊',
isShow: true
},
components: {
cpn: {
template: '#cpn',
data() {
return {
isShow: false
}
}
},
}
})
</script>
</body>
</html>
?安装使用路由
data:image/s3,"s3://crabby-images/631c7/631c70e1e7f3307498829f856886275da8984e38" alt=""
?data:image/s3,"s3://crabby-images/6f2f6/6f2f6ebe1d0d4aec45f01a2d5757948b89d5e092" alt=""
data:image/s3,"s3://crabby-images/7955e/7955ec8a61b0056a742f9f3040121ed8500c23b0" alt=""
?3.挂载到vue实例上
data:image/s3,"s3://crabby-images/7dbbe/7dbbead129e244e31413965750fbd45fc195a5dd" alt=""
?路由跳转的两种方式
?1.通过router-link跳转,router-view是跳转后的组件显示的位置
data:image/s3,"s3://crabby-images/206b0/206b004674f854c22f231bf99bd5bdfd3774fde4" alt=""
data:image/s3,"s3://crabby-images/24f42/24f42bfe679e787b2a5c95d119152a2f6565ad34" alt=""
?2.通过事件监听进行跳转
data:image/s3,"s3://crabby-images/11726/1172627b1cdd913ddcdf378681846964bea57117" alt=""
?data:image/s3,"s3://crabby-images/d906d/d906d5319bb50203203d5cf067f3b4466eff62f0" alt=""
router-link补充
data:image/s3,"s3://crabby-images/9ed16/9ed16ec205d55f5dfe9cf62bb25241e232b8b218" alt=""
?router-link默认是渲染成a标签,可以用tag修改
data:image/s3,"s3://crabby-images/b2d6d/b2d6d9455aedeef3d03aee4026e552fdcc1bd5fb" alt=""
active-class不需要每个标签都添加,可以再index文件中配置
data:image/s3,"s3://crabby-images/bcc6d/bcc6d8b6b8ae5cd1b85bcab3d76d93182c532a00" alt=""
data:image/s3,"s3://crabby-images/e9949/e994942cf192c1d9ffce3b3f7eba8e1778966214" alt=""
路由重定向,模式
模式
data:image/s3,"s3://crabby-images/820b4/820b4a90b5a75548c3dac095b18432cbb75a2788" alt=""
?重定向
data:image/s3,"s3://crabby-images/476e2/476e253d810cb029d08a9103c5712205f02e34b5" alt=""
动态路由
data:image/s3,"s3://crabby-images/23a6e/23a6e7678acbdafb21dfc7ee0f535fbb707ae227" alt=""
?data:image/s3,"s3://crabby-images/db0f4/db0f417319beb37de8178a5ff22ff1e735f99954" alt=""
?data:image/s3,"s3://crabby-images/fed2d/fed2d935b73b1d0f72c70fd89d6b4c4ef5b5becb" alt=""
?想要拿到动态的id
data:image/s3,"s3://crabby-images/3f592/3f59210de47df2ba6281ffed9f8fd027a699302f" alt=""
?data:image/s3,"s3://crabby-images/f9a5f/f9a5fd997b7bf5bc35af7b7a0d2a7050ce7630f8" alt=""
路由懒加载
data:image/s3,"s3://crabby-images/61582/615822e3e24ab8024f9d48e5f5e050d9be0b3366" alt=""
?嵌套路由
data:image/s3,"s3://crabby-images/d2323/d2323aad54e52f5fc4bd6e0392f559b0d48cac9d" alt=""
?data:image/s3,"s3://crabby-images/880da/880da10273ea70a4cdeecce70b5113bed43a8070" alt=""
?传递参数
data:image/s3,"s3://crabby-images/412b6/412b672a1d095d9a6cdf0e6ddaa7414789f7ceb0" alt=""
?data:image/s3,"s3://crabby-images/420c9/420c9fd3f25cdaae603191747330982b52830a71" alt=""
data:image/s3,"s3://crabby-images/e50ba/e50ba18a226030640da4f32ae70b6a0c7fe148fa" alt=""
?data:image/s3,"s3://crabby-images/de68b/de68bd4770a61391997bac5f331cfb89643e5d83" alt=""
?导航守卫
前置守卫beforeEach
data:image/s3,"s3://crabby-images/a0b90/a0b903eab17a671b188d8123cdcadd32d9a2573c" alt=""
?data:image/s3,"s3://crabby-images/5b867/5b867b182613d644b050f1b2bfbbddb08ac9933f" alt=""
?后置守卫
data:image/s3,"s3://crabby-images/04cfe/04cfeab92584b861984134b908234b038d6fce1b" alt=""
?keep-alive
data:image/s3,"s3://crabby-images/4f7f1/4f7f1593de1538870462eba6fb889fbc00b92be9" alt=""
?判断路由是否处于活跃状态的方法
data:image/s3,"s3://crabby-images/e09c3/e09c35ce92196254d03a70e4bdb987271fdfc231" alt=""
?给文件路径配置别名
data:image/s3,"s3://crabby-images/7b1be/7b1beafc0c4236e79af065fea61d9223f495536f" alt=""
?在脚手架3中在vue.config.js下配置
data:image/s3,"s3://crabby-images/3dff2/3dff2e654dfb345a4039a9b352c41e91495392bb" alt=""
?src下的路径需要加上~
data:image/s3,"s3://crabby-images/4deb1/4deb1dfd77bc881d7476e419614cc7eed124b947" alt=""
?vuex
main,js中的代码
import Vue from 'vue'
import App from './App'
import store from './store'
Vue.config.productionTip = false
new Vue({
el: '#app',
store,//*********
render: h => h(App)
})
index
data:image/s3,"s3://crabby-images/f36fc/f36fce90afc19c64bb7f3d77729530f7fd157c61" alt=""
?data:image/s3,"s3://crabby-images/d7ff0/d7ff05f6623137b6bebd5ea418fc325e2959d4fd" alt=""
?通过mutation来修改state
data:image/s3,"s3://crabby-images/b2032/b203298976960bb55ebf7047f00393cf7c173f0b" alt=""
?data:image/s3,"s3://crabby-images/fa983/fa9832613e125e50c102690764138934068dcd0b" alt=""
?data:image/s3,"s3://crabby-images/eb8e2/eb8e2e916fd3115e72d1614e1e5605c8642113d4" alt=""
mutations 携带参数
data:image/s3,"s3://crabby-images/04d9d/04d9d32e63f71338c4083e4dde1e2c3085bae33f" alt=""
1.正常的提交风格
data:image/s3,"s3://crabby-images/819e0/819e07a8b3a2a5fcb55d6a4ad0b9d964bd44f67a" alt=""
?data:image/s3,"s3://crabby-images/ef772/ef77241687bb1c7857e78f6d560da18df47db32c" alt=""
?2.特殊的提交风格
data:image/s3,"s3://crabby-images/51825/51825559875dabd2df4e7ff2a8bef7e86286dbc4" alt=""
?mutation响应规则
data:image/s3,"s3://crabby-images/51e5a/51e5aa64ff22a945b5a7dd1e7870feeebc131312" alt=""
?getter基本使用
data:image/s3,"s3://crabby-images/734bb/734bb086e5168da6aa1bda96348cfac9b9b01231" alt=""
?用getter里的方法不需要加()
data:image/s3,"s3://crabby-images/03143/03143d26927e0685afc69a212ce5ae8e1e6a2a72" alt=""
?action使用
现在组件中监听dispatch到vuex中的action里
data:image/s3,"s3://crabby-images/a62bc/a62bc24ab1de9b656b000897d2f7da6bc18ec2f6" alt=""
?action再commit到vuex中的mutation中data:image/s3,"s3://crabby-images/8da19/8da1931a48054126806e51bbdb7397cfb22a7872" alt=""
?data:image/s3,"s3://crabby-images/10125/10125c0da3b73da0bf5d58b3ecc8b01591a1afe7" alt=""
?vuex-module
data:image/s3,"s3://crabby-images/e4c5d/e4c5d255e1cfafdffb5185a8aee71dada65617cf" alt=""
p140
?vuex目录结构
就是把mutation,ation,getters,model打包起来,state不需要打包
data:image/s3,"s3://crabby-images/56ee2/56ee2a3fa2f79f008ade521f09134772f1079927" alt=""
?data:image/s3,"s3://crabby-images/acbd1/acbd14407db56e02c8a2c1bdb5753737df8fc46d" alt=""
?data:image/s3,"s3://crabby-images/05635/05635bd9fcccba100c16771d2b10a7bd15c97e74" alt=""
?vuex运用173p
data:image/s3,"s3://crabby-images/8fef5/8fef528ae64b2b501bffb66bc7fac653e1ffd61e" alt=""
?事件总线
data:image/s3,"s3://crabby-images/ab0c6/ab0c61f1d9818bb9489a0fdd9ba88ff9139fcd6a" alt=""
?
|