补充js的for循环:

// for in遍历的是取值关键 | for of遍历的是值

组件

概念:html, css, js的集合体命名 ,用该名字复用html,css,js组合成的集合体 体现了复用性

1.组件的分类:

// 根组件:new Vue() 生产的组件
// 局部组件: 组件名 = {} , {}内部采用的是vue语法
// 全局组件: Vue.component('组件名', {}) , {}内部采用的是vue语法

2.组件的特点

1.组件都有管理组件html页面的结果的 template实例成员, template中有且只有一个根标签

​ 挂载点本质是被组价template模块进行替换的占位符

// 总结: 根组件,可以不明确template, template默认采用挂载点页面结构:如果设置的template, 挂载点内部的内容无效,因为会被替换
// 解释: html, body 标签不能被替换,所以不能为挂载点.
// template 渲染真实dom 替换虚拟dom

2.根组件都是作为最顶层父组件, 局部与全局组价作为子组价, 也可以成为其他局部与全局的父组件

3.子组件的数据需要隔离(数据组件化,每一个组件拥有自己的数据的独立名称空间)

4.局部组件必须注册后才能使用,全局不需要注册,提倡使用局部组件

5.组件中出现的所有变量(模板中,逻辑中) 由该组价自己提供管理

6.局部 全局 根组件 都是一个vue实例, 一个实对应一套html, css, js结构, 所以实例就是组件

3.创建局部组件

// 声明局部组件:局部组件要在其父在组件中注册才能使用
// 1.声明组件 2.注册组件 3.渲染组件

声明:

let localTag = {
    template:'<a>pass</a>',
    methods:{
        pass
    }
}
// 注册在components:{}里注册 key 和 value 如果一样可以简写 key
Vue({
    el:'xx',
    components:{
        localTag
    }
})

但是在html中的tag不支持大写 所以用 - 来代替

<local-tag></local-tag>

4.全局组件

// 声明局部组件:局部组件要在其父在组件中注册才能使用
// 1.声明组件 2.渲染组件 
Vue.component('组件名', {
    template:'<a>pass</a>',
    methods:{
        pass
    }
} )
<组件名></组件名>

二.组件化

每个组件的数据应该是隔离的 但是data里的数据大家访问的都是同一个 所以要让他产生自己的局部作用域

let localTag = {
    data:funttion(){
    return {
    num:0
}
    data(){
        return {
            num:0
        }  // 数据需要组件化,作为方法的返回值(方法执行后会产生一个局部作用域)
    }
}
    template:'<a>{{num}}</a>',
    methods:{
        pass
    }
}
// 局部或全局取件,一个组件可能会被重复使用多次, 每个组件都应该有自己独立的名称空间
// 数据需要组件化,作为方法的返回值(return{} 里面放入数据就行)

一.组件传参父传子

// 1)子组件可以通过props自定义组件属性(采用反射机制,需要填写字符串,但是使用时可以直接作为变量)
// 2)子组件会在父组件中渲染,渲染时,将父组件的变量绑定给子组件的自定义属性,将可以将变量值传递给子组件

关键字:props

在子标签中规定自定义标签 然后在子组件中填写props:['xx'] 来获取对应的值

<text-tag :abc="xxx"></Text-tag>
let textTag ={
    props: ['xxx']
};

同时, 在里面调用该值也需要 使用属性绑定来获取 因为传来的是变量!

二.组件传参:子传父

// 自定义组件标签的事件
// 自定义事件是属于子组件的,子组件在父组件中渲染并绑定事件方法,所以事件方法由父组件来实现
// 子组件如何触发自定义事件:this.$emit('自定义事件名', 触发事件回调的参数们)
// 子组件触发自定义事件,携带出子组件的内容,在父组件中实现自定义事件的方法,拿到子组件传递给父组件的消息 

子组件如何触发自定义事件:

<!--this.$emit('自定义事件名', 触发事件回调的参数们)-->
<tag @action="actionFn"></tag>

父组件的methods方法

 methods: {
    actionFn(a, b, c) {
    // console.log('触发了', a, b, c);
    this.h1 = a;
    this.h3 = b;
    },
 }

子组件的methods方法

 methods: {
            changeTitle() {
                if (this.t1 && this.t2) {
                    this.$emit('action', this.t1, this.t2);
                }
            }
        }

Vue ---- 组价 组件化 子传父 父传子的更多相关文章

  1. Vue 入门之组件化开发

    Vue 入门之组件化开发 组件其实就是一个拥有样式.动画.js 逻辑.HTML 结构的综合块.前端组件化确实让大的前端团队更高效的开发前端项目.而作为前端比较流行的框架之一,Vue 的组件和也做的非常 ...

  2. Vue的父子组件v-model双向绑定,父组件修改子组件中绑定的v-model属性

    先来看下实现的效果,父组件中有个文本框,在点击下面按钮时弹出抽屉,抽屉里也有个文本框,文本框里的初始值要和父组件的文本框同步,并且修改抽屉里的文本框值时 父组件里的文本框值也要跟着改变 网上有大概三种 ...

  3. 【VUE】6.组件通信(一)父组件向子组件传值

    1. 前提&知识点 1./components/Father.vue 是父组件, Son.vue 是子组件 2.父组件像子组件通信 props 2.组件通信 1. 新增一个路由入口 /fath ...

  4. Vue 小实例 - 组件化 、cli 工程化

    1. 组件化  (父子组件通信: 父 - 子 :props 数组           子 - 父  :  子层触发事件,调用  $emit 触发父层对应自定义事件,可函数处理传参 / $event 获 ...

  5. vue中的组件化

    组件化 1.定义全局组件 1.要在父实例中使用某个组件,组件必须在实例值之前定义2.组件其实也是一个Vue实例,因此它在定义时也会接收:data.methond.生命周期函数等3.不同的组件不会与页面 ...

  6. Webpack+Vue+ES6 前端组件化开发mobile-multi-page应用实战总结和踩坑

    本文版权归博客园和作者吴双本人共同所有 转载和爬虫请注明原文地址 www.cnblogs.com/tdws 一.写在前面 项目上线有一段时间了,一个基于webpack+vue+ES6的手机端多页面应用 ...

  7. vue.js原生组件化开发(二)——父子组件

    前言 在了解父子组件之前应先掌握组件开发基础.在实际开发过程中,组件之间可以嵌套,也因此生成父子组件. 父子组件创建流程 1.构建父子组件 1.1 全局注册 (1)构建注册子组件 //构建子组件chi ...

  8. Webpack+Vue+ES6 前端组件化开发mobile-multi-page应用实战总结

    本文版权归博客园和作者吴双本人共同所有 转载和爬虫请注明原文地址 www.cnblogs.com/tdws 一.写在前面 项目上线有一段时间了,一个基于webpack+vue+ES6的手机端多页面应用 ...

  9. vue - 数据驱动,组件化, 双向绑定原理

    1.数据驱动 传统的前端数据交互是用Ajax从服务端获取数据,然后操作DOM来改变视图: Vue.js 是一个提供了 MVVM 风格的双向数据绑定的 Javascript 库,专注于View 层.它让 ...

随机推荐

  1. 红帽学习笔记[RHCE]网络配置与路由转发

    目录 网络配置基本的IPV4与IPV6 拓扑图 操作 新加一块网卡 将增加的网卡分别加到两台虚拟机上 在两台虚拟机上配置IPV4与 IPV6 配置域名访问 拓展路由转发 拓扑图 操作 关于网关设置 重 ...

  2. Linux下安装和使用WPS,体验良好

    最近,我在ubuntu18.04.3下面使用LibreOffice,感觉良好. 正值政府机关在进行2019年度正版软件使用情况整改,保护知识产权,我表示热烈欢迎并强烈支持. 通过摸底,因为以前采购的w ...

  3. for循环的更多写法

    在看设计模式这本书,遇到一个令人疑惑的for循环语句 for (var i = 0, type;type = ['String', 'Array', 'Number'][i++]) { 代码块 } 比 ...

  4. 微调(Fine-tune)原理

    在自己的数据集上训练一个新的深度学习模型时,一般采取在预训练好的模型上进行微调的方法.什么是微调?这里已VGG16为例进行讲解,下面贴出VGGNet结构示意图. 上面圈出来的是VGG16示意图,也可以 ...

  5. 题解 P1047 【校门外的树】

    可以直接模拟,用珂朵莉树是不有点小题大做. 你怎么做珂朵莉都会骂你:"这么简单的模拟都要用***" 附赠珂朵莉照片一张 另外讲几点: 可以用int,你要不怕MLE #include ...

  6. 各种优化方法总结比较(sgd/momentum/Nesterov/adagrad/adadelta)

    前言 这里讨论的优化问题指的是,给定目标函数f(x),我们需要找到一组参数x,使得f(x)的值最小. 本文以下内容假设读者已经了解机器学习基本知识,和梯度下降的原理. Batch gradient d ...

  7. linux 系统自动定制运行 crontab

    在UNIX下怎样实现和Windows下“计划任务”一样的功能 $crontab -e 编辑脚本 $crontab -l 察看脚本   用$crontab -e 编辑脚本,加入下列行 :分 小时 星期 ...

  8. css隐藏页面元素的多种方法

    在平常的样式排版中,我们经常遇到将某个模块隐藏,下面我整理了一下隐藏元素的多种方法以及对比(有的占据空间,有的不占据空间.有的可以点击,有的不能点击.): ( 一 )  display:  none; ...

  9. 在Spring Boot中添加全局异常捕捉提示

    在一个项目中的异常我们我们都会统一进行处理的,那么如何进行统一进行处理呢? 全局异常捕捉: 新建一个类GlobalDefaultExceptionHandler, 在class注解上@Controll ...

  10. SpringBoot使用拦截器、过滤器、监听器

    目录 ## 过滤器 PS: 原文链接https://www.cnblogs.com/haixiang/p/12000685.html,转载请注明出处 过滤器简介 过滤器的使用 拦截器 拦截器介绍 使用 ...