浅谈vue.js中的Props(单向数据流)

浅谈vue.js中的Props(单向数据流)

prop 是单向绑定的:当父组件的属性变化时,将传导给子组件,但是不会反过来。这是为了防止子组件无意修改了父组件的状态——这会让应用的数据流难以理解。

另外,每次父组件更新时,子组件的所有 prop 都会更新为最新值。这意味着你不应该在子组件内部改变 prop 。如果你这么做了,Vue 会在控制台给出警告。

通常有两种改变 prop 的情况:

prop 作为初始值传入,子组件之后只是将它的初始值作为本地数据的初始值使用;

立即学习“前端免费学习笔记(深入)”;

prop 作为需要被转变的原始值传入。

更确切的说这两种情况是:

1.定义一个局部 data 属性,并将 prop 的初始值作为局部数据的初始值。

props: ['initialCounter'],data: function () {  return { counter: this.initialCounter }}

登录后复制

2.定义一个 computed 属性,此属性从 prop 的值计算得出。

props: ['size'],computed: {  normalizedSize: function () {    return this.size.trim().toLowerCase()  }}

登录后复制

注意在 JavaScript 中对象和数组是引用类型,指向同一个内存空间,如果 prop 是一个对象或数组,在子组件内部改变它会影响父组件的状态。

英文原文地址:https://dev.to/lydiahallie/javascript-visualized-event-loop-3dif

相关推荐:

2020年前端vue面试题大汇总(附答案)

vue教程推荐:2020最新的5个vue.js视频教程精选

更多编程相关知识,请访问:编程入门!!

以上就是浅谈vue.js中的Props(单向数据流)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3023124.html

(0)
上一篇 2025年3月13日 06:03:17
下一篇 2025年2月28日 11:34:59

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 详解vue.js中watch的使用

    在vue中,使用watch来响应数据的变化。watch的用法大致有三种。下面代码是watch的一种简单的用法: 登录后复制登录后复制 new Vue({  el: ‘#root’,  data: {    cityName: ‘shangh…

    2025年3月13日
    200
  • 深入浅析With的使用

    with用于扩展一个语句的作用域链,但一般情况下不建议使用with语句,因为它可能是引起混淆错误和兼容性问题的根源。在Vue源码中有使用with语句的功能点,因此在这里将简介其功能,以助于阅读框架源码。 性能的利与弊 利 with语句可以在…

    2025年3月13日
    200
  • 浅谈Vue.use到底是什么?

    Vue.use到底是什么鬼、下面本篇文章就来给大家介绍一下Vue.use。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 我们在使用Vue做项目开发的时候,看到不少轮子都是通过Vue.use来进行使用,感觉甚是高大上。 不…

    2025年3月13日
    200
  • 浅谈Vue.js中双向绑定的原理及实现方法

    Vue最独特的特性之一,是其非侵入性的响应式系统。数据模型仅仅是普通的JavaScript对象。而当你修改它们时,视图会进行更新。vue通过双向绑定实现,本文就来为大家介绍一下vue双向绑定原理及实现方法。 本文主要介绍两大内容: 1. v…

    2025年3月13日 编程技术
    200
  • 详解vue.js中如何处理事件

    下面vue.js教程给大家介绍一下使用vue.js处理事件的方法,希望对大家有一定的帮助。 当您使用Vue构建动态网站时,您很可能希望它能够响应事件。 例如,如果用户单击按钮,提交表单,甚至只是移动鼠标,您可能希望您的Vue网站以某种方式做…

    2025年3月13日
    200
  • 实现带有进度条的Vue延迟加载

    下面vue.js栏目给大家介绍一下给vue的惰性加载添加进度条的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 简介 通常用 Vue.js 编写单页应用(SPA)时,当加载页面时,所有必需的资源(如 JavaScri…

    2025年3月13日
    200
  • 浅谈vue-cli初始化Vue项目的项目结构

    概述 vue-cli是vue 提供的一个官方命令行工具,可用于快速搭建大型单页应用。该工具提供开箱即用的构建工具配置,带来现代化的前端开发流程。只需几分钟即可创建并启动一个带热重载、保存时静态检查以及可用于生产环境的构建配置的项目。 使用v…

    2025年3月13日 编程技术
    200
  • 分析一下Vue.use的源码

    有过vue开发经验的,对于vue.use并不陌生。当使用vue-resource或vue-router等全局组件时,必须通过Vue.use方法引入,才起作用。那么vue.use在组件引入之前到底做了那些事情呢? 先上vue.use源码 Vu…

    2025年3月13日
    200
  • vue.js中如何使用v-for以及怎么获取索引?

    下面vue.js教程栏目带大家了解一下vue.js中v-for的使用及索引获取。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 登录后复制   变化如下: el处需id,写body报错;参数index需写在item后面;作…

    2025年3月13日
    200
  • 了解vue.js中的常用指令(总结)

    v-text v-text主要用来更新textContent,可以等同于JS的text属性。 // 等同于下方语句: {{text}} 登录后复制 v-html 双大括号的方式会将数据解释为纯文本,而非HTML。为了输出真正的HTML,可以…

    2025年3月13日
    200

发表回复

登录后才能评论