我的编程空间,编程开发者的网络收藏夹
学习永远不晚

VUE3的Non-Props属性怎么用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

VUE3的Non-Props属性怎么用

本篇内容介绍了“VUE3的Non-Props属性怎么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

    1. 概述

    墨菲定律告诉我们:人总是容易犯错误的,无论科技发展到什么程度,无论是什么身份的人,错误总是会在不经意间发生。因此我们最好在做重要的事情时,尽量去预估所有可能发生的错误,并思考错误发生后的补救方案,再准备一个或多个备选方案。这样才能做到有备无患,防患于未来。

    言归正传,之前我们聊了组件的传参,今天我们来聊一下Non-Props 属性,Non-Props 这个词,不了解的同学一定觉得很高深,其实很简单,之前讲的组件传参,子组件会使用 props:[''] 的方式接收父组件传递的参数,如果子组件不使用props:['']接收参数,那这个参数就是一个Non-Props 属性。下面我们通过例子来详细看一下。

    2.Non-Props 属性

    2.1 初识Non-Props 属性

    <body>    <div id="myDiv"></div></body><script>    const app = Vue.createApp({        template:`            <div>                <test message="hello" />            </div>        `    });    app.component("test", {        template:`            <div>123</div>        `    });    const vm = app.mount("#myDiv");

    这个例子中,虽然主组件在使用 test 子组件时,传了 message 参数,但子组件没有接收,会发生什么事情,看下面截图:

    VUE3的Non-Props属性怎么用

    最后渲染时,把 message = "hello" 原封不动的渲染到了 test 子组件的最外层标签上

    2.2 不想把Non-Props 属性 渲染到最外层标签

    我们希望我不接收的属性,就是不接收,不要渲染到最外层标签

    app.component("test", {        inheritAttrs:false,          template:`            <div>123</div>        `    });

    在子组件中增加属性inheritAttrs:false,Non-Props 属性就不会渲染到最外层标签了

    VUE3的Non-Props属性怎么用

    2.3Non-Props 属性的使用场景

    大家可能会问,这个属性子组件不需要,VUE 还硬放到子组件的最外层元素,这是为什么,有什么用呢,我们来看下面的例子

    const app = Vue.createApp({        template:`            <div>                <test  />            </div>        `    });    app.component("test", {        template:`            <div>123</div>        `    });

    VUE3的Non-Props属性怎么用

    VUE3的Non-Props属性怎么用

    从这个例子就能看出,当父组件想为子组件添加样式时,使用Non-Props 属性 就非常合适,也适合于其他单纯传递属性的场景。

    2.4 子组件有多个最外层标签

    刚才讲了,Non-Props 属性 会往子组件最外层的标签渲染属性,当子组件有多个最外层标签时,VUE 会如何渲染呢,看下面的例子

    const app = Vue.createApp({        template:`            <div>                <test  class="myClass" />            </div>        `    });    app.component("test", {        template:`            <div>123</div>            <div>456</div>            <div>789</div>        `    });

    VUE3的Non-Props属性怎么用

    三个最外层标签都没有父组件传递的属性,VUE 不知道该给哪个标签渲染,干脆就不渲染了

    2.5 为某个最外层标签渲染

    如果我们希望某个标签可以拿到父组件的属性,可以这样写

    const app = Vue.createApp({        template:`            <div>                <test  class="myClass" />            </div>        `    });    app.component("test", {        template:`            <div>123</div>            <div v-bind="$attrs" >456</div>            <div>789</div>        `    });

    VUE3的Non-Props属性怎么用

    使用 v-bind="$attrs",让 VUE 知道这个标签需要父组件的属性

    2.6 获取父组件传递的某一个属性

    上面的例子,子组件中间的 div 标签被渲染了父组件传递的所有属性,如果这个标签只需要的其中一个或几个属性,可以这么写

    const app = Vue.createApp({        template:`            <div>                <test  class="myClass" />            </div>        `    });    app.component("test", {        template:`            <div>123</div>            <div : >456</div>            <div>789</div>        `    });

    VUE3的Non-Props属性怎么用

    这样,中间的 div 只被渲染了 style 属性,而没有 class 属性

    2.7 生命周期函数获取Non-Props 属性

    子组件的生命周期函数,也是可以获取Non-Props 属性的,我们来看下面的例子

    app.component("test", {        mounted() {            console.info(this.$attrs.class);        },        template:`            <div>123</div>            <div : >456</div>            <div>789</div>        `    });

    VUE3的Non-Props属性怎么用

    “VUE3的Non-Props属性怎么用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    VUE3的Non-Props属性怎么用

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    VUE3的Non-Props属性怎么用

    本篇内容介绍了“VUE3的Non-Props属性怎么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 概述墨菲定律告诉我们:人总是容易犯
    2023-06-28

    React三大属性之props怎么用

    这篇文章主要介绍React三大属性之props怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!props功能在于组件间通信(父子组件),首先说说在各种组件中的用法:类组件//父组件传值class Father e
    2023-06-14

    vue属性props默认类型怎么写

    这篇“vue属性props默认类型怎么写”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue属性props默认类型怎么写”文
    2023-06-30

    Vue3中props和emit怎么使用

    这篇文章主要介绍“Vue3中props和emit怎么使用”,在日常操作中,相信很多人在Vue3中props和emit怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue3中props和emit怎么使用
    2023-07-05

    vue中组件的props属性有什么用

    这篇文章主要介绍vue中组件的props属性有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!问题一:那props具体是怎么使用呢?原理又是什么呢?往下看1、【定义被调用组件】首先,我们先定义一个person组件
    2023-06-25

    Vue3计算属性是怎么实现的

    今天小编给大家分享一下Vue3计算属性是怎么实现的的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。计算属性是 Vue.js 开
    2023-06-30

    Vue3中SetUp函数的props和context参数怎么用

    1.setUp函数的第1个参数propssetup(props,context){}第一个参数props:props是一个对象,包含父组件传递给子组件的所有数据。在子组件中使用props进行接收。包含配置声明并传入的所有的属性的对象也就是说:如果你想通过props的方式输出父组件传递给子组件的值。你需要使用props进行接收配置。即props:{......}如果你未通过Props进行接受配置,则输出的值是undefined父组件importNoContfrom"../componen
    2023-05-22

    Vue3中的计算属性及侦听器怎么使用

    计算属性我们知道,在模板中可以直接通过插值语法显示一些data中的数据,但是在某些情况,我们可能需要对数据进行一些转化后再显示,或者需要将多个数据结合起来进行显示在模板中使用表达式,可以非常方便的实现,但是设计它们的初衷是用于简单的运算,在模板中放入太多的逻辑会让模板过重和难以维护,并且如果多个地方都使用到,那么会有大量重复的代码所以我们希望将业务逻辑和UI界面进行分离,其中一种方式就是将逻辑抽取到一个method中,但这种做法有以下弊端所有的data使用过程都会变成了一个方法的调用多次获取数据
    2023-05-14

    Vue3中怎么使用watch监听对象的属性值

    这篇文章主要介绍“Vue3中怎么使用watch监听对象的属性值”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue3中怎么使用watch监听对象的属性值”文章能帮助大家解决问题。Vue3 中使用 w
    2023-07-04

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录