0828自我总结

Vue中组件

一.组件的构成

组件:由 template + css + js 三部分组成(.vue文件)

  • 1)组件具有复用性

    1. 复用组件时,数据要隔离
    1. 复用组件时,方法不需要隔离,因为方法使用隔离数据就可以产生区别

组件介绍:

    1. 每一个组件都有自己的template(虚拟DOM),最后要替换掉真实DOM(渲染)
    1. 挂载点el,在根组件没有规定template,用挂载的真实DOM拷贝出虚拟DOM,完成实例创建后再替换掉真实DOM(渲染)
    1. 挂载点el,在根组件规定template,就采用自己的template作为虚拟DOM,挂载点还是必须的,用于占位
    1. 所有 new Vue() 产生的组件都称之为根组件 - 项目开发时,整个项目只有一个根组件
    1. template只能解析一个根标签

二.template的使用

用法一-把整个vue所关联的内容替换

<div id="app">
{{ msg }}
</div>
<script src="vue.js"></script>
<script>
new Vue({
el: '#app',
data: {
msg: 'message'
},
// template: '<div id="main"><p>{{ msg }}</p><p>{{ msg }}</p></div>'
template: `
<div id="main">
<p>{{ msg }}</p>
<p>{{ msg }}</p>
</div>
`,
})
</script>

最后显示的效果为

message
message

其实他是先出现message

然后由于后面的template会生成一个临时的dom,会把前面el关联的整个标签变成template中的内容

用法二-局部组件

    <div id="app">
<!--3)组件渲染-->
<local-tag></local-tag>
<local-tag></local-tag>
<local-tag></local-tag>
</div>
<script src="js/vue.js"></script>
<script>
// 1)创建组件
let localTag = {
template: '<p>66666</p>'
};
new Vue({
el: '#app',
// 2)注册组件
components: {
// localTag: localTag, 函数名和组件名相同可以直接简写成一个名字
localTag
}
})
</script>

局部组件可以分三步

  • 创建组件
  • 注册组件
  • 网页中渲染

用法三-全局组件

<div id="main">
<global-tag></global-tag>
</div>
<script src="vue.js"></script>
<script>
// 全局组件
// 1)创建组件
// 2)渲染组件
// 3) 使用到全局组件的内容必须用Vue进行挂载,如果不挂载全局组件只是个普通的自定义标签
Vue.component('global-tag', {
template: '<p>66666</p>'
});
new Vue({
el: '#main',
});
</script>

使用到全局组件的内容必须用Vue进行挂载,如果不挂载全局组件只是个普通的自定义标签

注意点

  • template中只能有一个根标签,如果有多个,只生效第一个
  • template内容如果要多行显示方便观察的话用反引号`来代替双引号或者单引号

三.组件复用的数据隔离

1.局部组件中

    <div id="app">
<!--3)组件渲染-->
<local-tag></local-tag>
<local-tag></local-tag>
<local-tag></local-tag>
</div>
<script src="vue.js"></script>
<script>
// 1)创建组件
let localTag = {
data:function(){
return {
msg:100
}
},
template: '<p>{{msg}}</p>'
};
new Vue({
el: '#app',
// 2)注册组件
data:{
msg:20
},
components: {
// localTag: localTag, 函数名和组件名相同可以直接简写成一个名字
localTag
}
})
</script>
  • 把data里面值放function中当然了function可以不用写省略掉
  • 而且不会受vue中msg影响,只受组件中的msg影响

2,全局组件中

<div id="main">
<global-tag></global-tag>
</div>
//<global-tag></global-tag> 这样就是个普通的自定义标签
<script src="vue.js"></script>
<script>
// 全局组件
// 1)创建组件
// 2)渲染组件
// 3) 使用到全局组件的内容必须用Vue进行挂载,如果不挂载全局组件只是个普通的自定义标签
// 4) 这里的全局不是指整个网页而是指与vue进行挂载那些全部的部分
Vue.component('global-tag', {
data:function(){
return {
msg:100
}
},
template: '<p>{{msg}}</p>'
});
new Vue({
el: '#main',
data:{
msg:10
}
});
</script>

特点和局部相同

四.组件信息交互父传子

<div id="app">
<local-tag :ad_dic="ad" v-for="ad in ads" :key="ad.img"></local-tag>
</div>
<script src="js/vue.js"></script>
<script>
let localTag = {
props: ['ad_dic'],
template: `
<div class="ad">
<img :src="ad_dic.img" alt="">
<h4>{{ ad_dic.title }}</h4>
</div>
`,
}; // 模拟后台的数据
let ads = [
{
'img': 'img/001.png',
'title': '小猫'
},
{
'img': 'img/002.png',
'title': '黄蛋'
},
{
'img': 'img/003.png',
'title': '蓝蛋'
},
{
'img': 'img/004.png',
'title': '短腿'
},
];
new Vue({
el: '#app',
data: {
ads, // 后期项目是后台返回的数据
},
components: {
localTag
}
})
// 分析数据 父传子
// 1)父组件提供数据
// 2)在父组件模板中,为子组件标签设置自定义属性绑定父级数据
// 3)在子组件props成员中,接收自定义属性
// 4)在子组件模板和方法中,使用自定义属性名就可以访问父级数据
</script>

简单总结

父级模板:<local-tag :属性名="父级的数据" v-for="ad in ads" :key="ad.img"></local-tag>

子级模板: props: ['属性名'],

五.组件信息交互子传父

<div id="app">
<p>
<input type="text" v-model="info">
<button @click="add_msg">留言</button>
<ul>
<msg-tag @del_action="del_li" :msg="msg" :index="i" v-for="(msg, i) in msgs" :key="msg"></msg-tag>
</ul>
</p>
</div> <script src="js/vue.js"></script>
<script>
let msgTag = {
props: ['msg', 'index'],
template: `
<li>
<span @click="del_fn" class="del">x</span>
<span>{{ msg }}</span>
</li>
`,
methods: {
del_fn() {
this.$emit('del_action', this.index)
}
}
};
new Vue({
el: '#app',
components: {
msgTag
},
data: {
info: '',
msgs: JSON.parse(sessionStorage.msgs || '[]'),
},
methods: {
add_msg() {
let info = this.info;
if (info) {
this.msgs.unshift(this.info);
this.info = '';
sessionStorage.msgs = JSON.stringify(this.msgs);
}
},
del_li(index) {
console.log(index);
this.msgs.splice(index, 1);
sessionStorage.msgs = JSON.stringify(this.msgs);
}
}
});
// 分析数据 子传父
// 1)子组件提供数据
// 2)子组件通过系统事件激活自己的绑定方法,发送一个自定义事件,携带自身数据
// 3)在父组件模板中的子组件标签中为自定义事件绑定父组件方法
// 4)父组件实现方法获取到子组件数据
</script>

简单总结

子级模板: <span @系统自带的属性="子级方法" class="del">x</span>

子级实例方法中:this.$emit('自定义事件',子级数据们)

父级模板:<msg-tag @自定义事件="父级的方法" v-for="(msg, i) in msgs" :key="msg"></msg-tag>

父级方法: 父级的方法(子级的数据们){处理与子级相关的函数}

Vue中组件的更多相关文章

  1. vue中组件之间的通信

    一.vue中组件通信的种类 父组件向子组件的通信 子组件向父组件的通信 隔代组件之间的通信 兄弟 组件 之间的通信 二.实现通信的方式  props vue自定义的事件 消息订阅与发布 vuex sl ...

  2. Vue中组件间通信的方式

    Vue中组件间通信的方式 Vue中组件间通信包括父子组件.兄弟组件.隔代组件之间通信. props $emit 这种组件通信的方式是我们运用的非常多的一种,props以单向数据流的形式可以很好的完成父 ...

  3. Vue中组件化编码使用(实战练习一)

    Vue中组件化编码的大致流程(初接触).组件之间的参数传递(最基础的形式).组件之间的配合完成一个需求 1.在Vue中进行组件化编码 1.1.组件化编码流程: (1).拆分静态组件:组件要按照功能点拆 ...

  4. 038——VUE中组件之WEB开发中组件使用场景与定义组件的方式

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. Vue中组件之间的通信方式

    vue是数据驱动视图更新的框架, 所以对于vue来说组件间的数据通信非常重要,那么组件之间如何进行数据通信的呢? 本文会介绍组件间通信的8种方式如下图所示, 并介绍在不同的场景下如何选择有效方式实现的 ...

  6. Vue中组件化编码使用、实现组件之间的参数传递(实战练习二)

    上一章节实现的是静态页面的设计.这一章节实现将数据抽取出来.通过组件间参数的传递来实现 上一章节链接地址:https://blog.csdn.net/weixin_43304253/article/d ...

  7. vue中组件的四种方法总结

    希望对大家有用 全局组件的第一种写法 html: <div id = "app"> <show></show></div> js: ...

  8. vue中组件之间的相互调用,及通用后台管理系统左侧菜单树的迭代生成

    由于本人近期开始学习使用vue搭建一个后端管理系统的前端项目,在左侧生成菜单树的时候遇到了一些问题.在这里记录下 分析:由于本人设定的菜单可以使多级结构,直接使用vue的v-for 遍历并不是很方便. ...

  9. 二、vue中组件的使用

    1.组件拆分 1.组件实质上也是一个vue实例,因此组件中也可以使用vue的对象属性,反过来每一个vue实例也是一个vue组件(注:1.唯一不同的是el是根实例的特有选项,2.组件中的data必须是一 ...

随机推荐

  1. Python(Head First)学习笔记:三

    3 文件与异常:调试.处理错误.迭代.改进.完善  处理错误:利用Python的异常处理机制来处理异常情况.  程序外部的数据:大多程序基本模型:首先输入数据,进行处理,然后存储.显示.打印或传输. ...

  2. HTML5有哪些新特性,移除了哪些元素?如何处理HTML5新标签的浏览器兼容性问题?如何区分HTML和HTML5?

    HTML5现在已经不是SGML的子集,主要是关于图像,位置,存储,多任务等功能的增加. 绘画canvas: 用于媒介回放的video和audio元素: 本地离线存储localStorage长期存储数据 ...

  3. android中shape 的使用

    android 开发中 对于 shape 和 selector的使用,一直都不是很熟练, 记录一下.便于以后参考. 举个项目中例子图 对于上面的2个radiobutton ,背景我们可以让美工做一个. ...

  4. HBase常用操作之namespace

    1.介绍 在HBase中,namespace命名空间指对一组表的逻辑分组,类似RDBMS中的database,方便对表在业务上划分.Apache HBase从0.98.0, 0.95.2两个版本开始支 ...

  5. Hive介绍和安装部署

        搭建环境 部署节点操作系统为CentOS,防火墙和SElinux禁用,创建了一个shiyanlou用户并在系统根目录下创建/app目录,用于存放 Hadoop等组件运行包.因为该目录用于安装h ...

  6. IDEA基础设置

    1.防止自动更新 去掉 2.文件的隐藏 3.字体的修改: 4.字体格式 5.快捷键设置 --写出方法名,用Ctrl+Shift+Enter键补全. --移动当前行代码,用Ctrl+Shift+上.下. ...

  7. 探索form组件和cookie,session组件

    一. 实现注册功能 后端代码: from django.shortcuts import render,HttpResponse,redirect from app01 import models C ...

  8. 2019 DevOps 必备面试题——配置管理篇

    原文地址:https://medium.com/edureka/devops-interview-questions-e91a4e6ecbf3 原文作者:Saurabh Kulshrestha 翻译君 ...

  9. SpringBoot区块链之以太坊开发(整合Web3j)

    最近公司需要ETH兑换功能,ETH转账需要区块打包,这个时候就需要区块检测,目前只是简单整合,后面会将区块自动检测代码上传致QQ群 对于区块链开发不太熟悉的童鞋,可以看看:[区块链开发(零)如何开始学 ...

  10. 判断dom原始是否在可视区域内

    isElementInViewport (el, offset = 0) { const box = el.getBoundingClientRect(), top = (box.top >= ...