当前位置: 首页 > news >正文

自己的淘宝网站怎么建设推广app赚佣金

自己的淘宝网站怎么建设,推广app赚佣金,农产品的网站建设方案书范文,做招聘网站毕业设计一、前言 Vue官方文档Props单向数据流讲解 Vue中遵循单向数据流,所有的 props 都遵循着单向绑定原则,props 因父组件的更新而变化,自然地将新的状态向下流往子组件,而不会逆向传递。这避免了子组件意外修改父组件的状态的情况&a…

一、前言

Vue官方文档Props单向数据流讲解

Vue中遵循单向数据流,所有的 props 都遵循着单向绑定原则,props 因父组件的更新而变化,自然地将新的状态向下流往子组件,而不会逆向传递。这避免了子组件意外修改父组件的状态的情况,不然应用的数据流将很容易变得混乱而难以理解。

但是项目中总是有需求让我们来修改子组件内部传入的prop,所以才有了这篇文章,其实我们可以间接修改数据。

二、使用背景

父组件传递给子组件一个名为count数据,但是现在要在子组件中修改它的值并且实时更新页面,直接this.count是不能直接修改他的值的,控制台会报错,报错如下。所以我采用了下面两种方式间接更改。
在这里插入图片描述

三、解决方法

方法1:子组件通过computed计算属性来间接修改父组件传递的值

父组件传值

<GoodsBasic :renderObj='renderBasic' :count='count'></GoodsBasic>

子组件更改传入的值

<template><div class='goodsBasic'><div>{{ incrementCount}}</div><button @click='changeCount'>增加次数</button></div>
</template>
<script>
export default {props: {renderObj: {type: Object,default () {return {}}},count:{type: Number,default:0}},data () {return {increment: this.count //新定义一个变量,并把prop传进来的值作为初始值}},computed:{incrementCount(){ //当新定义的变量变更时,计算属性也会自动更新return this.increment}},methods: {changeCount(){this.increment++}}
}
</script>

方法2:子组件data中重新定义个局部数据,把父组件prop传来的数据作为初始值使用。

父组件传值

<GoodsBasic :renderObj='renderBasic' :count='count'></GoodsBasic>

子组件更改传入的值

<template><div class='goodsBasic'><div>{{ increment }}</div><button @click='changeCount'>增加次数</button></div>
</template>
export default {props: {renderObj: {type: Object,default () {return {}}},count:{type: Number,default:0}},data () {return {increment: this.count  //作为初始值使用,这样做就使prop和后续更新无关了}},methods: {changeCount(){this.increment++}}
}
</script>

四、更改对象 / 数组类型的 props

经过个人测试发现,当传入的prop为Object类型的时候,修改组件内部的prop可以对应的改变父组件中的值。如果传入的prop为简单类型(例如String,Number等)时,浏览器会报错,提示子组件不能修改prop的值。
比如上文例子更改 renderBasic.price控制台就不会报错。

个人感觉当传入的prop为引用类型时,子组件能直接修改父组件值,是因为在堆内存中公用同一个内存地址;修改的话只是改了它的值,而内存地址并没变,所以不报错;
基本数据类型修改会报错,原因是指向的内存地址要被迫修改,所以控制台报错。

另外Vue官方文档也说了:

当对象或数组作为 props 被传入时,虽然子组件无法更改 props 绑定,但仍然可以更改对象或数组内部的值。这是因为 JavaScript 的对象和数组是按引用传递,而对 Vue 来说,禁止这样的改动,虽然可能生效,但有很大的性能损耗,比较得不偿失。
这种更改的主要缺陷是它允许了子组件以某种不明显的方式影响父组件的状态,可能会使数据流在将来变得更难以理解。在最佳实践中,你应该尽可能避免这样的更改,除非父子组件在设计上本来就需要紧密耦合。在大多数场景下,子组件应该抛出一个事件来通知父组件做出改变。

目前我们公司有个项目就是就是因为父子组件数据需要紧密耦合的,所以直接在子组件更改了数据;
上面文档说的子组件应该抛出一个事件来通知父组件做出改变,意思就是子组件调用$emit抛出一个事件名,去通知父组件,值要改变了,在父组件写一个事件做后续处理。

想继续深入vue传值的问题,也可以去看我之前关于vue中传值方法的文章。
vue组件之间的传值方法(父子传值,兄弟传值,跨级传值,vuex)

http://www.rdtb.cn/news/18714.html

相关文章:

  • 做外贸仿牌网站宁波搜索引擎优化seo
  • 深圳市营销型网站网站提交入口
  • 网站开发语言是什么 东西bt磁力搜索器
  • 葫芦岛做网站价格彼亿营销
  • angular2做的网站有营销型网站建设价格
  • 网站建设丶金手指下拉13seo网站培训优化怎么做
  • 做团餐的企业网站seo网络优化推广
  • 做网站的团队业绩怎么写百度搜索指数排名
  • 搜索引擎推广实训杭州网站优化体验
  • 自学做网站多久软文有哪些推广渠道
  • 营销型网站建设标准南通网络推广
  • 女生做网站编辑好吗广州从化发布
  • wordpress调用tagseo公司后付费
  • 建设部工程业绩网站怎么自己创建网站
  • 做网站改版的公司网站的推广方案
  • 郑州网站建设怎样营销策划的重要性
  • 网站操作体验学市场营销后悔死了
  • 做电子外贸网站建设磁力狗在线引擎
  • 中山做营销型网站公司近三年成功的营销案例
  • 网站建设明细报价表 xls好看的seo网站
  • 做电影网站如何推广竞价推广开户公司
  • 安利的网站谁做的西安seo关键字优化
  • 网站ww正能量品牌公关公司
  • 合肥企业网站建设网络营销手段有哪些
  • 网站图片怎么替换国际新闻稿件
  • 投资公司网站建设方案最火的网络推广平台
  • 如何建设cpa影视网站佛山seo
  • 宣传网站建设重庆百度seo
  • 建网站的公司哪个好在线推广企业网站的方法有
  • 阿里网站建设需要准备什么软件数字营销网站