详解Vue.js分发之作用域槽
网络编程 2021-07-04 18:32www.168986.cn编程入门
本篇文章主要介绍了详解Vue.js分发之作用域槽,长沙网络推广觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随长沙网络推广过来看看吧
首先,需要知道的是,每个组件有每个组件自己的作用域。每个组件都是Vue()的实例,有自己的作用域。
比如现在有个组件这样的:
Vue.ponent('father-ponent1',{ template:'<div class="father"><p>Hi,我是父组件</p>{{fatherMessage}}</div>', data:function(){ return { fatherMessage:'这是父组件发出的消息哦~' } }, });
这个data只为template里的模板服务。同样的,子组件的data只为子组件的模板服务。因为他们都是各自作用域内的属性。
在slot分发中,无论是单分发还是具名分发,都是父组件替换子组件的数据,或者没有替换,用子组件默认的数据。两者并不能共存。这样他们就没有数据联系了。
但是通过设置作用域槽,就可以改变这种状况,让子组件可以在父组件进行分发时获取自己的数据,至于是什么数据,由子组件决定,这样就能解耦了。
作用域槽通过slot的一个自定义的属性,官方给出的DEMO是text,但也可以是其他,值为暴露的数据。
这个自定义属性已经存放在子组件的prop对象里了。等待着被父组件获取。
怎么获取呢?
在父组件的模板里,使用一个Vue自带的特殊组件<template> ,并在该组件上使用scope属性,值是一个临时的变量,存着的是由子组件传过来的prop对象,在狼蚁网站SEO优化的例子中我把他命名为props。
获得由子传过来的prop对象。这时候,父组件就可以访问子组件在自定义属性上暴露的数据了。
//js Vue.ponent('child-ponent4',{ template:'<ul>' + '<slot name="child-ul" v-for="item in fruit" v-bind:text="item.name">?</slot>' + '</ul>', data:function(){ return { fruit:[ {name:'苹果'}, {name:'香蕉'}, {name:'橙子'} ] } }, }); Vue.ponent('father-ponent4',{ template:'<child-ponent4>' + '<template scope="props" slot="child-ul">' + '<li class="child-li" >{{props.text}}</li>' + '</template>' + '</child-ponent4>' }); var app16 = new Vue({ el:'#app16' }); <div id="app16"> <father-ponent4></father-ponent4> </div>
以上的的组件组合会被渲染为:
<div id="app16"> <ul> <li class="child-li">苹果</li> <li class="child-li">香蕉</li> <li class="child-li">橙子</li> </ul> </div>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 机械手焊接机器人编程 机械手焊接设备编程
- vb数据库编程实例,vb做数据库
- tiobe世界编程语言排行榜,全球编程语言排行
- 成都java编程培训 成都it编程培训中心
- 编程基础培训,编程基础知识培训
- flash游戏编程基础教程,flash游戏开发教程
- 不会英语能学编程吗 不会英语可以学程序员吗
- 爱心代码编程C语言 爱心代码编程c语言公式
- c语言编程学习入门 c语言编程快速入门
- 西门子plc编程培训 西门子plc编程培训班
- 哪里可以学编程 台州哪里可以学编程
- 少儿编程哪个好 少儿编程哪个品牌好
- 编程是什么意思,图形编程是什么意思
- c语言编程软件下载,c语言编程软件在哪下载
- java编程软件下载,java编程下载手机版
- ug编程培训学校,ug编程培训教程