IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 29 Vue中的Non-props使用$attrs & inheritAttrs -> 正文阅读

[JavaScript知识库]29 Vue中的Non-props使用$attrs & inheritAttrs

阐述

这节我们主要讲一下 Non-props 属性,那什么是 Non-props 属性呢?

其实就是子组件没有接受父组件传递过来的参数,而子组件完全不变的复制了属性到自己的标签上,就叫做Non-props属性。

我相信你现在还不能完全理解这句话,无所谓,我们继续学习。

基础页面和子组件的准备

为了展示 Non-props 属性的风采,我们需要编写一下讲解使用的代码,你可以把这个过程当作复习。

代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Demo29</title>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/3.0.2/vue.global.js"></script>
</head>
<body>
    <div id="app"></div>
</body>
<script>
    const app = Vue.createApp({
        template: `<h2>willem</h2>`
    })
    const vm = app.mount("#app")
</script>
</html>

然后我们再编写一个Hello的全局组件,

代码如下:

app.component('Hello', {
    template: `<h3>Hello World</h3>`
})

写好子组件后,在父组件中直接使用即可。

const app = Vue.createApp({
    template: `
        <h2>willem.com</h2>
        <hello />
    `
})

初始 Non-props 属性

上面的代码,我们并没有在子组件里接受任何传递过来的参数,就根本没有写 props,但这时候在调用的时候,是仍然可以传值的。

const app = Vue.createApp({
    template: `
	    <h2>willem.com</h2>
	    <hello msg="mybj" />
	`
})

这时候你打开浏览器中的控制台,查看 Elements 标签,可以看到此时的 <h3> 标签上已经有了 msg=mybj 这样的属性,也就是父组件直接把属性移植给了子属性。

在这里插入图片描述
如果要消除 这种移植,或者是复制,可以在子组件里接受这个属性,但并不使用他。

app.component('Hello', {
     props: ['msg'],
     template: `<h3>Hello World</h3>`
})

这时候在打开浏览器的Elements标签查看,就没有多余的属性了。

两种方式理解后,我们再来说什么是 Non-prop 属性,它就是父组件向子组件传递参数的时候,子组件不写任何的接受方法。这个时候父组件就会直接把属性完全复制给子组件,子组件也是可以得到属性值的。

最常见的使用案例就是直接在标签上写CSS样式。

const app = Vue.createApp({
    template: `
        <h2>willem.com</h2>
        <hello style="color:red;" />
    `
})

这时候子组件会直接得到这个属性,也就把字体变成了红色。

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Demo29</title>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/3.0.2/vue.global.js"></script>
</head>
<body>
    <div id="app"></div>
</body>
<script>
    const app = Vue.createApp({
        template: `
            <h2>willem.com</h2>
            <hello style="color:red;" />
        `
    })

    app.component('Hello', {
         props: ['msg'],
         template: `<h3>Hello World</h3>`
    })
    
    const vm = app.mount("#app")
</script>
</html>

inheritAttrs 属性

有些时候我们就是不想接受参数,也不想让 Non-props 属性起作用,这时候可以在子组件上使用 inheritAttrs 属性来解决这个问题。

app.component('Hello', {
    inheritAttrs: false,
    template: `<h3>Hello World</h3>`
})

这时候 style 标签就不会再被复制到子组件上了,组件上的 Hello World 也不会变成红色了。

Non-Prop 多节点失效解决方法

刚才说了,组件在没有接受参数时,会把属性自动复制到组件的根节点上,如果组件不是一个根节点,比如写成下面的样子。

app.component('Hello', {
    template: `
        <h3>Hello World</h3>
        <h3>Hello World</h3>
        <h3>Hello World</h3>
    `
})

这时候复制就会失效。

你当然可以给他们增加一个根节点,但是在不增加根节点的条件下,也是有办法解决的。比如现在我们想让第一个组件中的<h3>标签复制父组件传递过来的属性,就可以写成下面的样子。

app.component('Hello', {
    template: `
	    <h3 v-bind="$attrs">Hello World</h3>
	    <h3>Hello World</h3>
	    <h3>Hello World</h3>
	`
})

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Demo29</title>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/3.0.2/vue.global.js"></script>
</head>
<body>
    <div id="app"></div>
</body>
<script>
    const app = Vue.createApp({
        template: `
            <h2>willem.com</h2>
            <hello style="color:red;" />
        `
    })

    app.component('Hello', {
        template: `
            <h3 v-bind="$attrs">Hello World</h3>
            <h3>Hello World</h3>
            <h3>Hello World</h3>
        `
    })

    const vm = app.mount("#app")
</script>
</html>

注意,测试的 $attrs 不是单指某一个属性,而是指全部属性。
当然这里只有一个属性,所以只复制了一个,比如你再写一个属性,它也是可以复制过来的。

const app = Vue.createApp({
    template: `
	    <h2>willem.com</h2>
	    <hello style="color:green;" msg="mybj" />
	`
})

这时候你打开浏览器,会看到两个属性都复制到了第一个<h3>标签上。

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Demo29</title>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/3.0.2/vue.global.js"></script>
</head>
<body>
    <div id="app"></div>
</body>
<script>
    const app = Vue.createApp({
        template: `
            <h2>willem.com</h2>
            <hello style="color:green;" msg="mybj" />
        `
    })

    app.component('Hello', {
        template: `
            <h3 v-bind="$attrs">Hello World</h3>
            <h3>Hello World</h3>
            <h3>Hello World</h3>
        `
    })

    const vm = app.mount("#app")
</script>
</html>

这点需要注意一下,v-bind="$attrs"的意思是把父组件传递的所以参数属性都复制到子组件当中。

如果你想只复制一个属性,比如现在我们只复制一个属性style,这么写:

app.component('Hello', {
    template: `
        <h3 v-bind="$attrs">Hello World</h3>
        <h3 v-bind:style="$attrs.style">Hello World</h3>
        <h3>Hello World</h3>
    `
})

在这里插入图片描述
这时候第二个 <h3>标签就只复制了style属性。
当然你也可以简写,去掉v-bind,而是用 : 代表。

app.component('Hello', {
    template: `
        <h3 v-bind="$attrs">Hello World</h3>
        <h3 :style="$attrs.style">Hello World</h3>
        <h3>Hello World</h3>
    `
})

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Demo29</title>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/3.0.2/vue.global.js"></script>
</head>
<body>
    <div id="app"></div>
</body>
<script>
    const app = Vue.createApp({
        template: `
            <h2>willem.com</h2>
            <hello style="color:green;" msg="mybj" />
            <Welcome style="color:red;" msg="mybj" />
        `
    })

    app.component('Hello', {
        template: `
            <h3 v-bind="$attrs">Hello World</h3>
            <h3 v-bind:style="$attrs.style">Hello World</h3>
            <h3>Hello World</h3>
        `
    })

    app.component('Welcome', {
        template: `
            <h3 v-bind="$attrs">Hello World</h3>
            <h3 :style="$attrs.style">Hello World</h3>
            <h3>Hello World</h3>
        `
    })

    const vm = app.mount("#app")
</script>
</html>

在业务逻辑中使用 Non-props 属性

刚才讲的都是在标签上使用 Non-props 属性,如果你想在业务逻辑中使用 Non-props 属性也是可以的。比如在生命周期中使用。

app.component('Hello', {
    mounted() {
        console.log(this.$attrs.msg)
    },
    template: `
    <h3 v-bind="$attrs">Hello World</h3>
    <h3 v-bind:style="$attrs.style">Hello World</h3>
    <h3>Hello World</h3>
    `
})

然后到浏览器中的控制台进行查看,就可以看到打印出了 mybj 字样。其实 this.$attrs 是Vue的一个常用属性,我们需要善于利用。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Demo29</title>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/3.0.2/vue.global.js"></script>
</head>
<body>
    <div id="app"></div>
</body>
<script>
    const app = Vue.createApp({
        template: `
            <h2>willem.com</h2>
            <hello style="color:green;" msg="mybj" />
            <Welcome style="color:red;" msg="mybj" />
        `
    })

    app.component('Welcome', {
        template: `
            <h3 v-bind="$attrs">Hello World</h3>
            <h3 :style="$attrs.style">Hello World</h3>
            <h3>Hello World</h3>
        `
    })

    app.component('Hello', {
        mounted() {
            console.log(this.$attrs.msg)
        },
        template: `
        <h3 v-bind="$attrs">Hello World</h3>
        <h3 v-bind:style="$attrs.style">Hello World</h3>
        <h3>Hello World</h3>
        `
    })

    const vm = app.mount("#app")
</script>
</html>
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-12-04 13:21:37  更:2021-12-04 13:23:06 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 14:18:50-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码