Vue 基础学习(五)
作者:Studying_swz
- 2022-11-12 天津
本文字数:4734 字
阅读完需:约 16 分钟
data:image/s3,"s3://crabby-images/11eba/11eba43f027550b1fcd04490ec843eec7d41ab17" alt="Vue基础学习(五)"
推荐 Vscode 编译器、vue 官网:https://cn.vuejs.org/v2/guide/installation.html
1.组件化
data:image/s3,"s3://crabby-images/4ce13/4ce13ba1e13d658f28b85e4765100b5cff23617a" alt=""
data:image/s3,"s3://crabby-images/910de/910de7956b66429cb1e247958df5736d644cfd29" alt=""
2.注册组件
data:image/s3,"s3://crabby-images/a1204/a12045405b4702511b4c3d555354aec2394b9e06" alt=""
<!DOCTYPE html>
<html lang='en'>
<head>
<meta charset='UTF-8'>
<meta name='viewport' content='width=device-width, initial-scale=1.0'>
<title>Document</title>
</head>
<body>
<div id='app'>
<!-- //3.使用组件 -->
<my-cpn></my-cpn>
</div>
<script src='../js/vue.js'></script>
<script>
//1.创建组件构造器对象(es6 ` 可以换行不用+)
const cpnC = Vue.extend({
template: `
<div>
<h2>我是标题</h2>
<p>我是内容,哈哈哈</p>
<p>我是内容,呵呵呵</p>
</div>`
})
//2.注册组件
Vue.component('my-cpn',cpnC)
const app = new Vue({
el:'#app', //用于挂载要管理的元素
data:{ //定义数据
message: '你好啊,李银河!',
name: 'codewhy'
}
})
</script>
</body>
</html>
复制代码
3.注册组件步骤解析
data:image/s3,"s3://crabby-images/20198/2019898c6c131b801e5f8508a19461253f855ef1" alt=""
data:image/s3,"s3://crabby-images/8f545/8f545fc71594cb55fc8273587c2d851005f3aebd" alt=""
注:必须在 new Vue 挂载的实例之下,才被渲染出来
4.全局组件和局部组件
<!DOCTYPE html>
<html lang='en'>
<head>
<meta charset='UTF-8'>
<meta name='viewport' content='width=device-width, initial-scale=1.0'>
<title>Document</title>
</head>
<body>
<div id='app'>
<cpn></cpn>
<cpn></cpn>
</div>
<div id='app2'>
<cpn></cpn>
</div>
<script src='../js/vue.js'></script>
<script>
//1.创建组件构造器对象(es6 ` 可以换行不用+)
const cpnC = Vue.extend({
template: `
<div>
<h2>我是标题</h2>
<p>我是内容,哈哈哈</p>
<p>我是内容,呵呵呵</p>
</div>`
})
//2.注册组件(全局组件),意味着可以在多个Vue的实例下面使用
//Vue.component('my-cpn',cpnC)
const app = new Vue({
el:'#app', //用于挂载要管理的元素
data:{ //定义数据
message: '你好啊,李银河!',
name: 'codewhy'
},components: {
//局部组件:
// cpn 使用组件时候的标签名
cpn:cpnC
}
});
const app2 = new Vue({
el:'#app2', //用于挂载要管理的元素
data:{ //定义数据
message: '你好啊,李银河!',
name: 'codewhy'
}
})
</script>
</body>
</html>
复制代码
data:image/s3,"s3://crabby-images/5ce19/5ce197c49c013c715ff921d15f16053b1c2e95d1" alt=""
data:image/s3,"s3://crabby-images/9820e/9820e2b4f00b50006b99269d26139247aa915fdf" alt=""
5.父组件和子组件
<!DOCTYPE html>
<html lang='en'>
<head>
<meta charset='UTF-8'>
<meta name='viewport' content='width=device-width, initial-scale=1.0'>
<title>Document</title>
</head>
<body>
<div id='app'>
<cpn2></cpn2>
</div>
<div id='app2'>
<cpn></cpn>
</div>
<script src='../js/vue.js'></script>
<script>
//1.创建第一个组件
const cpnC1 = Vue.extend({
template: `
<div>
<h2>我是标题1</h2>
<p>我是内容,哈哈哈</p>
</div>`
});
//2.创建第二个组件(父组件)
const cpnC2 = Vue.extend({
template: `
<div>
<h2>我是标题2</h2>
<p>我是内容,呵呵呵</p>
<cpn1></cpn1>
</div>`,
components:{
cpn1:cpnC1
}
});
//root组件
const app = new Vue({
el:'#app', //用于挂载要管理的元素
data:{ //定义数据
message: '你好啊,李银河!',
name: 'codewhy'
},components: {
//2.注册:局部组件:
// cpn 使用组件时候的标签名
cpn2:cpnC2
}
});
</script>
</body>
</html>
复制代码
data:image/s3,"s3://crabby-images/a780a/a780a471ae7f97e42b6742467fffb6b41779780a" alt=""
6.注册组件的语法糖
data:image/s3,"s3://crabby-images/a861f/a861fd63dc80959d7220b9b8a47afb3a49e7728c" alt=""
data:image/s3,"s3://crabby-images/a0942/a094280056ba227103b3531405762909291de3a6" alt=""
data:image/s3,"s3://crabby-images/d7f21/d7f21a464120c395a48b1e549a7b98d473197691" alt=""
7.模板的分类写法
全局组件分离
<!DOCTYPE html>
<html lang='en'>
<head>
<meta charset='UTF-8'>
<meta name='viewport' content='width=device-width, initial-scale=1.0'>
<title>Document</title>
</head>
<body>
<div id='app'>
<cpn></cpn>
</div>
<!-- 1.第一种 -->
<!-- <script type="text/x-template" id="cpn">
<div>
<h2>我是标题</h2>
<p>我是内容</p>
</div>
</script> -->
<!-- 2.第二种 -->
<template id="cpn">
<div>
<h2>我是标题</h2>
<p>我是内容</p>
</div>
</template>
<script src='../js/vue.js'></script>
<script>
//1.注册一个全局组件
Vue.component('cpn',{
template:`#cpn`
})
const app = new Vue({
el:'#app', //用于挂载要管理的元素
data:{ //定义数据
message: '你好啊,李银河!',
name: 'codewhy'
}
})
</script>
</body>
</html>
复制代码
局部组件分离
<!DOCTYPE html>
<html lang='en'>
<head>
<meta charset='UTF-8'>
<meta name='viewport' content='width=device-width, initial-scale=1.0'>
<title>Document</title>
</head>
<body>
<div id='app'>
<cpn></cpn>
</div>
<!-- 1.第一种 -->
<!-- <script type="text/x-template" id="cpn">
<div>
<h2>我是标题</h2>
<p>我是内容</p>
</div>
</script> -->
<!-- 2.第二种 -->
<template id="cpn">
<div>
<h2>我是标题</h2>
<p>我是内容</p>
</div>
</template>
<script src='../js/vue.js'></script>
<script>
const app = new Vue({
el:'#app', //用于挂载要管理的元素
data:{ //定义数据
message: '你好啊,李银河!',
name: 'codewhy'
},
components: {
'cpn':{
template:'#cpn'
}
}
})
</script>
</body>
</html>
复制代码
8.组件数据
data:image/s3,"s3://crabby-images/9bc3c/9bc3cfb50c17fe017d321f853b5f8cbf33859e9d" alt=""
注:组件内不能访问 data 数据,所以 Vue 组件因该有自己保存数据的地方
data:image/s3,"s3://crabby-images/ba2d4/ba2d4f6813a80e2d57c352c0f45a5bb6da2217b1" alt=""
为什么必须是一个函数?
data:image/s3,"s3://crabby-images/365a2/365a298a0744d764e9ede0ccc64c0ca400ce8651" alt=""
9.父子间通信
data:image/s3,"s3://crabby-images/2e898/2e898491c44b340cfb7f13ab3099758c4a02d14f" alt=""
10.父级向子级传递
data:image/s3,"s3://crabby-images/5452a/5452ae8044a1fd9bd9271ace1e42a40b59d3e785" alt=""
<!DOCTYPE html>
<html lang='en'>
<head>
<meta charset='UTF-8'>
<meta name='viewport' content='width=device-width, initial-scale=1.0'>
<title>Document</title>
</head>
<body>
<div id='app'>
<cpn :cmovies='movies' :cmessage='message'></cpn>
</div>
<template id="cpn">
<div>
<ul>
<li v-for="item in cmovies">{{item}}</li>
</ul>
<p> {{cmessage}}</p>
<h2>{{cmovies}}</h2>
</div>
</template>
<script src='../js/vue.js'></script>
<script>
// 父传子:props
//局部组件
const cpn = {
template:'#cpn',
//props: ['cmovies','cmessage']
props:{
//1.类型限制
//cmovies:Array,
//cmessage:String
//2.提供一些默认值
cmessage:{
type:String,
default:"aaaaa",
required:true ///必传
},
//类型是对象或数组的时候,默认值必须是一个函数
cmovies:{
type:Array,
default(){
return []
}
}
}
}
const app = new Vue({
el:'#app', //用于挂载要管理的元素
data:{ //定义数据
message: '你好啊,李银河!',
name: 'codewhy',
movies: ['海','王者','夏洛特']
},
components: {
'cpn':cpn
}
})
</script>
</body>
</html>
复制代码
数据验证的写法(props 对象)
11.props 驼峰标识
注:vue 不支持直接的驼峰标识,需要进一步的转换,如:childMyMessage,需要在绑定的时候使用:child-my-message
<!DOCTYPE html>
<html lang='en'>
<head>
<meta charset='UTF-8'>
<meta name='viewport' content='width=device-width, initial-scale=1.0'>
<title>Document</title>
</head>
<body>
<div id='app'>
<cpn :cinfo='info' :child-my-message ="message"></cpn>
</div>
<template id="cpn">
<!-- 如果有多个标签,需要外部有个div包起来 -->
<div>
<h2>{{cinfo}}</h2>
<h2>{{childMyMessage}}</h2>
</div>
</template>
<script src='../js/vue.js'></script>
<script>
const cpn = {
template: '#cpn',
props:{
cinfo:{
type : Object,
default(){
return {}
}
},
childMyMessage:{
type : String,
default : ''
}
}
}
const app = new Vue({
el:'#app', //用于挂载要管理的元素
data:{ //定义数据
message: '你好啊,李银河!',
name: 'codewhy',
info:{
name: 'why',
age: 18,
height: 1.88
}
},
components: {
'cpn':cpn
}
})
</script>
</body>
</html>
复制代码
12.子级向父级传递
注:发射事件,自定义事件,子传父;然后父组件监听事件,注意名字不要用驼峰标识。
<!DOCTYPE html>
<html lang='en'>
<head>
<meta charset='UTF-8'>
<meta name='viewport' content='width=device-width, initial-scale=1.0'>
<title>Document</title>
</head>
<body>
<!-- 父组件模板 -->
<div id='app'>
<cpn v-on:itemclick="cpnClick"></cpn>
</div>
<!-- 子组件模板 -->
<template id="cpn">
<!-- 如果有多个标签,需要外部有个div包起来 -->
<div>
<button v-for='item in categories' @click="btnClick(item)">{{item.name}}</button>
</div>
</template>
<script src='../js/vue.js'></script>
<script>
///1.子组件
const cpn = {
template: '#cpn',
data(){
return {
categories:[
{id: 'aaa',name: '热门推荐'},
{id: 'bbb',name: '手机数码'},
{id: 'ccc',name: '家用家电'},
{id: 'ddd',name: '电脑办公'},
]
}
},methods:{
btnClick(item){
//console.log(item);
// 发射事件,自定义事件,子传父
this.$emit('itemclick',item)
}
}
}
//2.父组件
const app = new Vue({
el:'#app', //用于挂载要管理的元素
data:{ //定义数据
message: '你好啊,李银河!',
name: 'codewhy'
},
components: {
cpn
},methods:{
cpnClick(item){
console.log('cpnClick',item);
}
}
})
</script>
</body>
</html>
复制代码
划线
评论
复制
发布于: 刚刚阅读数: 3
版权声明: 本文为 InfoQ 作者【Studying_swz】的原创文章。
原文链接:【http://xie.infoq.cn/article/6d56acde21a84d6c457b8e5fc】。文章转载请联系作者。
data:image/s3,"s3://crabby-images/fcb03/fcb0384ae2dcb9b19f2dd2dc6999370011fa3e2a" alt="用户头像"
Studying_swz
关注
还未添加个人签名 2020-12-23 加入
还未添加个人简介
评论