这篇文章将为大家详细讲解有关Vue.js分发之作用域槽的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
创新互联主要为客户提供服务项目涵盖了网页视觉设计、VI标志设计、营销推广、网站程序开发、HTML5响应式成都网站建设公司、成都手机网站制作、微商城、网站托管及网站建设维护、WEB系统开发、域名注册、国内外服务器租用、视频、平面设计、SEO优化排名。设计、前端、后端三个建站步骤的完善服务体系。一人跟踪测试的建站服务标准。已经为成都水处理设备行业客户提供了网站营销服务。首先,需要知道的是,每个组件有每个组件自己的作用域。每个组件都是Vue()的实例,有自己的作用域。
比如现在有个组件这样的:
Vue.component('father-component1',{ 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对象,在下面的例子中我把他命名为props。
获得由子传过来的prop对象。这时候,父组件就可以访问子组件在自定义属性上暴露的数据了。
//js Vue.component('child-component4',{ 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.component('father-component4',{ template:'<child-component4>' + '<template scope="props" slot="child-ul">' + '<li class="child-li" >{{props.text}}</li>' + '</template>' + '</child-component4>' }); var app16 = new Vue({ el:'#app16' }); <div id="app16"> <father-component4></father-component4> </div>
以上的的组件组合会被渲染为:
<div id="app16"> <ul> <li class="child-li">苹果</li> <li class="child-li">香蕉</li> <li class="child-li">橙子</li> </ul> </div>
关于“Vue.js分发之作用域槽的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
分享标题:Vue.js分发之作用域槽的示例分析-创新互联
当前网址:https://www.cdcxhl.com/article32/dgecsc.html
成都网站建设公司_创新互联,为您提供标签优化、虚拟主机、企业网站制作、全网营销推广、关键词优化、网站排名
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联