vue之props传值与单向数据流
(1)组件通信
父组件向子组件传递数据。这个正向传递数据的过程就是通过props来实现的。
两者区别:props中声明的数据与组件data函数return返回的数据的主要区别就是props来自父级,而data中是组件自己的数据,作用域是组件本身,这两种数据都可以在模板template、计算属性computed、方法methods中使用。
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>demo1</title>
<script type="text/javascript" src="vue-2.6.9.min.js"></script>
</head>
<body>
<div id="demo">
<textarea v-model="message" v-bind:placeholder="placeholder"></textarea>
<demo-component v-bind:message="message"></demo-component>
</div>
<script type="text/javascript">
Vue.component('demo-component',{
props:['message'],
template:`
<div class="demo-area">
{{message}}
</div>
`
});
var demo = new Vue({
el:'#demo',
data:{
message:'来自父级的数据',
placeholder:'请输入'
}
})
</script>
</body>
</html>
(2)单向数据流
业务中会经常遇到两种需要改变props的情况,一种是父组件传递初始值进来,子组件将它作为初始值保存起来,在自己的作用域下可以随意使用和修改。这种情况可以在组件data中再声明一个数据,引用父组件的prop
<div id="demo">
<demo-component v-bind:initcount="initcount"></demo-component>
</div>
<script type="text/javascript">
Vue.component('demo-component',{
props:['initcount'],
template:`
<div class="demo-area">
{{count}}
</div>
`,
data:function(){
return {
count:this.initcount
}
}
});
var demo = new Vue({
el:'#demo',
data:{
'initcount':'1'
}
});
</script>
组件里声明了数据count,它在组件初始化时会获取来自父级组件的initcount,之后便与之无关,只用维护count,这样就可以避免直接操作initcount。
(3)另一种情况就是prop作为需要被转变的原始值传入,这种情况用计算属性即可。
<div id="demo">
<demo-component v-bind:width="width"></demo-component>
</div>
<script type="text/javascript">
Vue.component('demo-component',{
props:['width'],
template:`
<div class="demo-area" v-bind:style="style">
组件内容
</div>
`,
computed:{
style(){
return {width:this.width+'px'};
}
}
});
var demo = new Vue({
el:'#demo',
data:{
'width':
}
});
</script>
.
vue之props传值与单向数据流的更多相关文章
- vue第十八单元(单向数据流 vuex状态管理)
		第十八单元(单向数据流 vuex状态管理) #课程目标 1.理解什么是数据管理模式 2.什么是vuex 3.什么时候使用vuex 4.vuex安装及工作原理 5.vuex语法 #知识点 1.首先来看下 ... 
- Vue props 单向数据流
		1.props通信 注意:DOM模板的驼峰命名props要转为短横分割命名. <!DOCTYPE html> <html lang="zh"> <he ... 
- Vue 父子组件传值 props
		1.Vue 的渲染周期: vue 如何实现响应式追踪. 父子组件通信有很多方式,今天单独聊下props 的方式.我们通过查找官方文档很容发现,props传值有静态和动态两种传值方式. 当然props ... 
- Vue 组件&组件之间的通信 之 单向数据流
		单向数据流:父组件值的更新,会影响到子组件,反之则不行: 修改子组件的值: 局部数据:在子组件中定义新的数据,将父组件传过来的值赋值给新定义的数据,之后操作这个新数据: 如果对数据进行简单的操作,可以 ... 
- vue第九单元(非父子通信 events 单向数据流)
		第九单元(非父子通信 events 单向数据流) #课程目标 了解非父子组件通信的原理,熟练实现非父子组件间的通信(重点) 了解单向数据流的含义,并且明白单向数据流的好处 #知识点 #1.非父子组件间 ... 
- vue 单向数据流 & 双向绑定
		在react中是单向数据绑定,而在vue中的特色是双向数据绑定.但是其实就我个人的理解是: 其实无论是vue还是react其实还是提倡单向数据流去管理状态,这一点在vuex和redux状态管理器上体现 ... 
- 关于Vue中props的详解
		看一下官方文档: 组件实例的作用域是孤立的.这意味着不能 (也不应该) 在子组件的模板内直接引用父组件的数据.父组件的数据需要通过 prop 才能下发到子组件中. 也就是props是子组件访问父组件数 ... 
- vue-父子组件之传值和单项数据流问题
		前言 我们知道 vue 中父子组件的核心概念是单项数据流问题,props 是单项传递的.那究竟什么是单项数据流问题,这篇文章来总结一下关于这个知识点的学习笔记. 正文 1.父组件传值给子组件 < ... 
- React 精要面试题讲解(一) 单向数据流
		react 单向数据流概念 'react框架是怎样的数据流向?'||'react单向数据流是怎样的概念 ?' 解答这个问题之前,我们首先得知道,js框架是个怎样的概念. 框架:具备一定**编程思想** ... 
随机推荐
- 【T^T 1736】【FJUTOJ 1077】排座位
			http://59.77.139.92/problem.php?id=1077 水题,小心PE // <1736.cpp> - 11/12/16 17:17:52 // This file ... 
- BZOJ_3172_[Tjoi2013]单词_AC自动机
			BZOJ_3172_[Tjoi2013]单词_AC自动机 Description 某人读论文,一篇论文是由许多单词组成.但他发现一个单词会在论文中出现很多次,现在想知道每个单词分别在论文中出现多少次. ... 
- [Codeforces 545E] Paths and Trees
			[题目链接] https://codeforces.com/contest/545/problem/E [算法] 首先求 u 到所有结点的最短路 记录每个节点最短路径上的最后一条边 答 ... 
- 【Jsoi2010】连通数
			[题目链接] 点击打开链接 [算法] 直接暴力dfs一遍,即可 [代码] #include<bits/stdc++.h> using namespace std; #define MAXN ... 
- 腾讯API
			相关文档: API列表 腾讯开放平台联调工具集 公共返回码说明 SDK下载 
- MVC视图中下拉框的使用
			一.一般变量或对象的绑定 首先要在controller 中将选项设置成 selecList对象,并赋值给viewBag动态对象. public ActionResult Index(string mo ... 
- bzoj 3609: [Heoi2014]人人尽说江南好【博弈论】
			参考:https://blog.csdn.net/Izumi_Hanako/article/details/80189596 胜负和操作次数有关,先手胜为奇,所以先手期望奇数后手期望偶数,最后一定能达 ... 
- P3171 [CQOI2015]网络吞吐量
			传送门 首先跑一遍最短路,如果一条边满足\(dis[v]=dis[u]+w[i]\),那么这条边就在最短路中,把它加进网络流的图里 然后点的流量限制的话拆点,把每个点拆成两个,中间连边来限制流量 最后 ... 
- 标准行cp功能
			#include<stdio.h> int main(int argc,char *argv[]) { FILE *src_fp,*des_fp; ]={}; ) { printf(&qu ... 
- not and or
			not and or (逻辑表达式) 首先要做一些准备知识: 1,优先级:逻辑型 < 测试型 < 关系型 < 算数型 2,逻辑型优先级:or < and < not 3, ... 
