1.背景

2.简单使用

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!-- <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>-->
<script src="../js/vue.js"></script>
</head>
<body>
<h2>父组件与子组件</h2>
<pre>
这个概念很好理解:
组件中 包含 组件 结构层了父组件与子组件的关系
</pre>
<hr>
<div id="app">
<!-- 5.使用父组件-->
<c-parent></c-parent>
</div>
<script>
// 1.创建组件构造器(子组件)
const componentChild = Vue.extend({
// 相当于一个模板
template: ' <div>' +
' <h5>我是 子组件</h5>' +
' 你好,我是自定义的子组件......' +
' </div>'
})
// 2.创建组件构造器(父组件组件)
const componentParent = Vue.extend({
template: '<div>' +
' <h4>我是 父类主键</h4>' +
' 你好,我是自定义的父组件......' +
' <c-child></c-child>' +
' </div>',
// 3.注册子组件到父组件中
components: {
'c-child': componentChild
}
}) let app = new Vue({
el: '#app',
// 4.注册父组件到vue实例中
components: {
'c-parent': componentParent
}
})
</script>
</body>
</html>

3.语法糖-简写

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!-- <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>-->
<script src="../js/vue.js"></script>
</head>
<body>
<h2>组件简写</h2>
<pre>
就是相当于把第一步创建组件构造器合并在注册组件的时候写
</pre>
<hr>
<div id="app">
<!-- 2.使用组件-->
<c-my></c-my>
</div>
<script>
let app = new Vue({
el: '#app',
// 1.创建主键并注册
components: {
'c-my': {
template: '<div>我是简写的组件</div>'
}
}
})
</script>
</body>
</html>

4.语法糖-简写-子父组件

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!-- <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>-->
<script src="../js/vue.js"></script>
</head>
<body>
<h2>组件简写-子父组件</h2>
<pre>
就是相当于把第一步创建组件构造器合并在注册组件的时候写
</pre>
<hr>
<div id="app">
<!-- 2.使用组件-->
<c-parent></c-parent>
</div>
<script>
let app = new Vue({
el: '#app',
// 1.创建主键并注册
components: {
'c-parent': {
template: '<div>我是简写的父组件<c-child></c-child></div>',
components: {
'c-child': {
template: '<div>我是简写的子组件</div>'
}
}
}
}
})
</script>
</body>
</html>

5.模板与js代码分离

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!-- <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>-->
<script src="../js/vue.js"></script>
</head>
<body>
<h2>组件-模板与js分离</h2>
<pre>
在之前的写法中js与模板的html代码柔和在一起了,如果模板代码比较多写起来很痛苦,
必须将模板定义在外边,
实现很简单弄个id就可以了
</pre>
<hr>
<div id="app">
<!-- 2.使用组件-->
<c-parent></c-parent>
</div>
<!--父模板-->
<template id="parentId">
<div>我是模板分离的父组件
<c-child></c-child>
</div>
</template>
<!--子模板-->
<template id="childId">
<div>我是模板分离的子组件
</div>
</template>
<script>
let app = new Vue({
el: '#app',
// 1.创建主键并注册
components: {
'c-parent': {
template: '#parentId',
components: {
'c-child': {
template: '#childId'
}
}
}
}
})
</script>
</body>
</html>

6.组件中数据访问

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!-- <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>-->
<script src="../js/vue.js"></script>
</head>
<body>
<h2>组件-中数据的访问</h2>
<pre>
1.组件不能直接访问Vue实例数据,请自己测试,{{message}} 2.组件对象也有一个data属性(也可以有methods等属性,下面我们有用到)
只是这个data属性必须是一个函数
而且这个函数返回一个对象,对象内部保存着数据
</pre>
<hr>
<h2>案例如下:</h2>
<div id="app">
<!-- 2.使用组件-->
<c-parent></c-parent> </div>
<!--父模板-->
<template id="parentId">
<div>我是模板分离的父组件,父模板中的数据:{{messageParent}}
<c-child></c-child>
</div>
</template>
<!--子模板-->
<template id="childId">
<div>我是模板分离的子组件
</div>
</template>
<script>
let app = new Vue({
el: '#app',
// 1.创建主键并注册
components: {
'c-parent': {
template: '#parentId',
// 组件中数据存放
data() {
return {
messageParent: '我是父组件中的数据'
}
},
components: {
'c-child': {
template: '#childId'
}
}
}
}
})
</script>
</body>
</html>

完美!

vue之父组件与子组件的更多相关文章

  1. vue中父级与子组件生命周期的先后顺序

    1.vue的生命周期 2.views/createrCustormer.vue为父级     <template>     <expressService />   </ ...

  2. vue 父组件传递子组件事件

    在开发中,碰到一个需要从父组件传入方法,子组件点击触发,说白了就是,把方法传入给子组件调用 <el-col v-for='data in spreadFormat.icons' class=&q ...

  3. Vue中,父组件向子组件传值

    1:在src/components/child/文件夹下,创建一个名为:child.vue的子组件 2:在父组件中,设置好需要传递的数据 3:在App.vue中引入并注册子组件 4:通过v-bind属 ...

  4. VUE 父组件与子组件交互

    1. 概述 1.1 说明 在项目过程中,会有很多重复功能在多个页面中处理,此时则需要把这些重复的功能进行单独拎出,编写公用组件(控件)进行引用.在VUE中,组件是可复用的VUE实例,此时组件中的dat ...

  5. Vue父组件向子组件传递一个动态的值,子组件如何保持实时更新实时更新?

    原文:https://blog.csdn.net/zhouweixue_vivi/article/details/78550738 2017年11月16日 14:22:50 zhouweixue_vi ...

  6. Vue 组件&组件之间的通信 之 父组件向子组件传值

    父组件向子组件传值:父组件通过属性向下传值的方式和子组件通信: 使用步骤: 定义组件:现有自定义组件com-a.com-b,com-a是com-b的父组件: 准备获取数据:com-b要获取父组件dat ...

  7. vue+elementUI项目,父组件向子组件传值,子组件向父组件传值,父子组件互相传值。

    vue+elementUI项目,父组件向子组件传值,子组件向父组件传值,父子组件互相传值. vue 父组件与子组件相互通信 一.父组件给子组件传值 props 实现父组件向子组件传值. 1父组件里: ...

  8. Vue系列之 => 父组件向子组件传值

    父组件向子组件传递数据 1 <!DOCTYPE html> 2 <html lang="en"> 3 4 <head> 5 <meta c ...

  9. vue 父组件给子组件传值 Vue父组件给子组件传方法 Vue父组件把整个实例传给子组件

    Home.vue <template> <!-- 所有的内容要被根节点包含起来 --> <div id="home"> <v-header ...

  10. vue 的父组件和子组件互相获取数据和方法

    父组件主动获取子组件的数据和方法 一.ref(但不能实时更新获取) 1.调用子组件的时候 定义一个ref <child ref="headerChild"></c ...

随机推荐

  1. Java动态获取实现类 Class.forName(clazz).newInstance()和applicationContext.getBean, bean Map寻找方式,Java Map定义和初始化方法

    Java动态获取实现类 Class.forName(clazz).newInstance()和applicationContext.getBean, bean Map寻找方式,Java Map定义和初 ...

  2. Excel poi 设置单元格格式 发现不可读内容 已修复的记录: /xl/worksheets/sheet1.xml 部分的问题(巨坑)

    Excel poi 设置单元格格式 发现不可读内容 已修复的记录: /xl/worksheets/sheet1.xml 部分的问题(巨坑) 1.先设置值,后设置样式. 正确的是:先设置样式,后设置值. ...

  3. [笔记]Git常用命令大全

    Tips:当你看到这个提示的时候,说明当前的文章是由原emlog博客系统搬迁至此的,文章发布时间已过于久远,编排和内容不一定完整,还请谅解` [笔记]Git常用命令大全 日期:2018-6-16 阿珏 ...

  4. Kotlin 编程语言详解:特点、应用领域及语法教程

    什么是 Kotlin? Kotlin 是一种现代.流行的编程语言,由 JetBrains 在 2016 年发布. 自发布以来,它已经变得非常流行,因为它与 Java 兼容(Java 是目前最流行的编程 ...

  5. python中dict和list的数据结构

    要理解dict的有关内容需要你理解哈希表(map)的相关基础知识,这个其实是<算法与数据结构>里面的内容. 1.list和tuple其实是用链表顺序存储的,也就是前一个元素中存储了下一个元 ...

  6. AIGC的行业发展

    1. AIGC的行业发展 AIGC(Artificial Intelligence Generated Content,人工智能生成内容)是利用人工智能技术来自动生成内容的一种新型内容创作方式.它基于 ...

  7. mac idea 配置Tomcat

    官网下载Tomcat 下载地址:点我直达 配置Idea 设置Application Servers 操作步骤:Intellij IDEA->Preferences->Application ...

  8. Jingle Bio:产品出海的最重要一课是「重营销轻技术」?

    名字: Jingle Bio 开发者 / 团队: Luo Baishun 平台: Web 请简要介绍下这款产品 Jingle Bio 是一款不需要任何编程基础就可以轻松驾驭的个人网站制作工具,你可以使 ...

  9. [WUSTCTF2020]朴实无华(命令执行)

    请求头问题 去查了一下资料了解了一下没有什莫用 robots.txt 中有东西 假flag 但是请求头里有重要消息 访问页面/fl4g.php <img src="/img.jpg&q ...

  10. [oeasy]python0143_主控程序_main

    主控程序 回忆上次内容 上次把 apple.py 拆分成了 输入 主函数   引用模块中变量的时候 要带上包(module)名 get_fruits.a get_fruits.b     最终 拆分代 ...