ref

当ref写在一个标签元素中,通过this.$refs.name 获取的是标签对应的dom元素


<section id="app"
ref="froggy"
@click="handleClick"
>{{name}}</section> <script>
var vm = new Vue({
el: "#app",
data:{
name:"emit"
},
methods:{
handleClick: function() {
console.log(this.$refs.froggy)
alert("this.$refs.froggy")
}
}
})
</script>

当ref写在一个组件上的时候。获取的是一个子组件的引用

<section id="app"
ref="froggy"
>
<counter @change="handle" ref="one"></counter>
<counter @change="handle" ref="two"></counter>
{{name}}</section> <script> Vue.component("counter", {
template:"<div @click='handleClick'>{{number}}</div>>",
data:function() {
return {
number: 0
}
},
methods: {
handleClick: function() {
this.number++
this.$emit("change")
}
}
}) var vm = new Vue({
el: "#app",
data:{
name:"0"
},
methods:{
handle: function() {
this.name = this.$refs.one.number + this.$refs.two.number
}
}
})
</script>

is = " 子组件名称"(属性)

H5有一些编码规范

<ul> --<li>

<ol> --<li>

<select> --<option>

<table> --<tbody> -- <tr> --<td>

非子组件中定义data要用function + return

子组件不像根组件只调用一次,子组件会被不断调用,不希望子组件中数据冲突

每个子组件都有独立的数据存储,多个子组件间互相影响

父子组件传值

父 --- 子  通过属性形式传递 //  子组件不能修改父组件传递过来的参数(万一是引用类型)

子组件可以在自己的数据内clone一份  然后更改

<article class="app">
<counter :count="0"></counter>
</article> <script> var counterr = {
props:["count"],
template:"<section @click='handle'>{{number}}</section>",
data: function () {
return {
number: this.count
}
},
methods: {
handle:function() {
this.number++
}
}
} var vm = new Vue({
el: ".app",
data:{ },
components:{
counter:counterr
}
})
</script>

子组件通过时间触发机制向父组件传值

this.$emit("事件名称",传递参数,可以多个)

子组件上; @事件名称=“父组件调用的函数”

组件参数校验

父组件向子组件传递参数的时候,子组件可以对数据进行约束

props: {
content: {
type: String, 类型
required: false //must send
default: "default" //默认值
validator: function(value) {
return value.length > 5 //验证器 true 返回 自定义效验器
}}

非props特性

父子组件之间props有个对用关系  为props特性

  • 不会在dom标签上显示
  • {{content}}  this.content 可以拿到数据

子组件不定义。不接受父组件传过来content。子组件不能使用数据

会显示在dom中

组件绑定原生事件

< child @click.native="handleClick">  自定义click事件 后面加一个native修饰符。

非父子组件传值

框架

总线/bus/发布订阅模式/观察者模式

vue组件使用细节的更多相关文章

  1. Laravel 项目中编写第一个 Vue 组件

    和 CSS 框架一样,Laravel 不强制你使用什么 JavaScript 客户端框架,但是开箱对 Vue.js 提供了良好的支持,如果你更熟悉 React 的话,也可以将默认的脚手架代码替换成 R ...

  2. 深入理解 Vue 组件

    深入理解 Vue 组件 组件使用中的细节点 使用 is 属性,解决组件使用中的bug问题 <!DOCTYPE html> <html lang="en"> ...

  3. 滴滴开源 Vue 组件库— cube-ui

    cube-ui 是滴滴去年底开源的一款基于 Vue.js 2.0 的移动端组件库,主要核心目标是做到体验极致.灵活性强.易扩展以及提供良好的周边生态-后编译. 自 17 年 11 月开源至今已有 5 ...

  4. vue组件中—bus总线事件回调函数多次执行的问题

    在利用vue组件进行事件监听时发现,如果对N个vue组件实例的bus总线绑定同一事件的回调函数,触发任意组件的对应事件,回调函数至少会被执行N次,这是为什么呢? 为此,调研了普通对象的事件绑定和触发实 ...

  5. 2.基础:Vue组件的核心概念

    一.组件基础和注册 组件概念 组件系统是 Vue 的另一个重要概念,他的核心就是封装和复用. 细节 组件的name必须是全局唯一. 二.属性.事件和插槽 组件的三大核心概念:属性.事件和插槽. 属性, ...

  6. 深入理解Vue组件3大核心概念

    摘要: 搞懂Vue组件! 作者:浪里行舟 原文:详解vue组件三大核心概念 Fundebug经授权转载,版权归原作者所有. 前言 本文主要介绍属性.事件和插槽这三个vue基础概念.使用方法及其容易被忽 ...

  7. vue组件开发练习--焦点图切换

    1.前言 vue用了有一段时间了,开发的后台管理系统也趋于完善,现在时间比较算是有点空闲吧!这个空闲时间我在研究vue的另外的一些玩法,比如组件,插件等.今天,我就分享一个组件的练手项目--焦点图切换 ...

  8. 第四章、深入理解vue组件

    4-1.使用组件的细节 a.使用is解决html出现bug 如下 table下面应该为tr,所以页面渲染的时候没有找到tr是有问题的,所以是有小bug,所以table中必须是tr b.改上面bug,t ...

  9. vue组件库用markdown生成文档

    前言: 开发vue组件库需要提供组件的使用文档,最好是有渲染到浏览器的demo实例,既能操作又能查看源代码.markdown作为常用的文档编写载体,如果能在里面直接写vue组件,同时编写使用说明就再好 ...

随机推荐

  1. 吴裕雄--天生自然java开发常用类库学习笔记:属性类Properties

    import java.util.Properties; public class PropertiesDemo01{ public static void main(String args[]){ ...

  2. Codeforces 1111C Creative Snap分治+贪心

    Creative Snap C. Creative Snap time limit per test 1 second memory limit per test 256 megabytes inpu ...

  3. 完全卸载(删除)mac下自带的php

    /private/etc sudo rm -rf php-fpm.conf.defaultphp.ini php.ini.default /usr/bin sudo rm -rf php php-co ...

  4. 【pwnable.kr】cmd1

    最近的pwnable都是linux操作系统层面的. ssh cmd1@pwnable.kr -p2222 (pw:guest) 首先还是下载源代码: #include <stdio.h> ...

  5. 解决CSS背景模糊

    .banner{ background:url(banner.jpg); -moz-background-size:100% 100%; background-size:100% 100%; }

  6. 云时代架构阅读笔记二——Java性能优化(二)

    承接上文Java性能优化(一)https://www.cnblogs.com/guo-xu/p/11019267.html 4)尽量确定StringBuffer的容量 在说和这个标题相关之前,先说一下 ...

  7. systemctl无法停掉keepalived

    这个问题搞了好半天,记录一下,启停都是用的systemctl 起初是测试vip漂移时候发现,主备节点都开启keepalived的状况下,一切正常,主节点的vip也可以访问. 第一次停掉主节点的keep ...

  8. 090-PHP数组过滤函数array_filter

    <?php function odd($x){ //定义过滤偶数的函数 if($x%2==1) return TRUE; } function even($x){ //定义过滤奇数的函数 if( ...

  9. React 学习笔记(3) B站视频总结1

    视频地址 项目基础 react-cli // 项目结构 src │ App.js # 应用根组件 │ index.js # 入口js ├─api ├─assets ├─components ├─con ...

  10. 操作CLOB数据——oracle

    DECLARE V_UPDATE CLOB := '{"cpc_msg_tel":"15098025316","cvm_money":&qu ...