> 웹 프론트엔드 > View.js > Vue의 슬롯에 대해 알아보기

Vue의 슬롯에 대해 알아보기

青灯夜游
풀어 주다: 2020-10-14 17:41:45
앞으로
2430명이 탐색했습니다.

Vue의 슬롯에 대해 알아보기

Vue 슬롯은 Vue 학습에 없어서는 안 될 부분입니다. 제가 Vue를 처음 접했을 때 저는 이러한 개념, 특히 스코프 슬롯에 대해 조금밖에 이해하지 못했습니다.

나중에 슬롯이 점점 더 유용하다는 것을 알게 되었습니다.

슬롯에 대한 지식을 공유하세요.

1. 슬롯 콘텐츠

한 문장으로 말하면 슬롯에는 모든 콘텐츠가 포함될 수 있습니다.

먼저 다음 코드를 살펴보세요. 하위 구성 요소 구성 요소를 선언합니다.

이제 안에 콘텐츠를 배치하려는 경우 결과는 어떻게 될까요?

<div id="app">
    <child-component></child-component>

</div>
<script>
    Vue.component(&#39;child-component&#39;,{
        template:`
            <div>Hello,World!</div>
        `
    })
    let vm = new Vue({
        el:&#39;#app&#39;,
        data:{

        }
    })
</script>
로그인 후 복사
<child-component>你好</child-component>
로그인 후 복사

출력 내용은 여전히 ​​구성 요소의 내용이며 에 작성된 내용은 효과가 없습니다.

Vue의 슬롯에 대해 알아보기

이제 슬롯을 컴포넌트에 추가합니다.

에 작성한 "Hello"가 작동합니다! ! !

Vue.component(&#39;child-component&#39;,{
        template:`
            <div>
            Hello,World!
            <slot></slot>
            </div>
        `
    })
로그인 후 복사

Vue의 슬롯에 대해 알아보기

이제 우리는 슬롯이 무엇인지 알았습니다.

Slot은 배포된 콘텐츠를 전달하기 위한 콘센트로 요소를 사용하여 Vue에서 구현한 콘텐츠 배포 API 세트입니다.

이 문장의 의미는 슬롯이 없으면 구성 요소 태그의 일부 내용이 아무런 영향을 미치지 않는다는 것입니다. 구성 요소에서 슬롯 요소를 선언하면 구성 요소 요소에 작성된 내용이 해당 위치로 실행됩니다!

2. 명명된 슬롯

명명된 슬롯은 이 슬롯에 이름을 지정합니다.

컴포넌트에서 슬롯에 이름을 지정합니다. 하나는 "girl", 다른 하나는 "boy", 또 다른 이름입니다. 기억이 나지 않습니다.

그러면 에서 슬롯 속성에 해당하는 콘텐츠가 구성 요소의 이름과 일대일로 대응됩니다.

이름 없는게 기본 슬롯이에요! !

<div id="app">
    <child-component>
        <template slot="girl">
            漂亮、美丽、购物、逛街
        </template>
        <template slot="boy">
            帅气、才实
        </template>
        <div>
            我是一类人,
            我是默认的插槽
        </div>
    </child-component>
</div>
<script>
    Vue.component(&#39;child-component&#39;,{
        template:`
            <div>
            <h4>这个世界不仅有男人和女人</h4>

            <slot name="girl"></slot>

            <div style="height:1px;background-color:red;"></div>

            <slot name="boy"></slot>

            <div style="height:1px;background-color:red;"></div>

            <slot></slot>
            </div>
        `
    })
    let vm = new Vue({
        el:&#39;#app&#39;,
        data:{

        }
    })
</script>
로그인 후 복사

3. 스코프 슬롯

이전에는 스코프 슬롯이 무엇인지 전혀 이해하지 못했습니다! ! !

직설적으로 말하면 컴포넌트 요소 내에서 사용할 수 있는 컴포넌트의 내 속성입니다!

먼저 가장 간단한 예부터 살펴보겠습니다! !

요소에 속성을 정의한 다음(원하는 대로 정의합니다!) 구성요소 하위를 사용한 다음 템플릿 요소에 슬롯 범위 속성을 추가합니다! ! 임의의 이름을 지정합니다

a를 인쇄하여 슬롯의 속성과 값으로 구성된 키-값 쌍인 {"say" : "Hello"}임을 확인합니다! ! !

스코프 슬롯이에요!

컴포넌트 요소에 컴포넌트의 속성/값을 사용할 수 있어요! !

<div id="app">
    <child>
        <template slot-scope="a">
      <!-- {"say":"你好"} -->

            {{a}}
        </template>
    </child>
</div>
<script>
    Vue.component(&#39;child&#39;,{
        template:`
            <div>
                <slot say="你好"></slot>
            </div>
        `
    })

    let vm = new Vue({
        el:&#39;#app&#39;,
        data:{

        }
    })
</script>
로그인 후 복사

아래 예를 다시 살펴보세요.

<div id="app">
    <child :lists="nameList">
        <template slot-scope="a">
            {{a}}
        </template>
    </child>
</div>
<script>
    Vue.component(&#39;child&#39;,{
        props:[&#39;lists&#39;],
        template:`
            <div>
                <ul>
                    <li v-for="list in lists">
                        <slot :bbbbb="list"></slot>
                    </li>
                </ul>
            </div>
        `
    })

    let vm = new Vue({
        el:&#39;#app&#39;,
        data:{
            nameList:[
            {id:1,name:&#39;孙悟空&#39;},
            {id:2,name:&#39;猪八戒&#39;},
            {id:3,name:&#39;沙和尚&#39;},
            {id:4,name:&#39;唐僧&#39;},
            {id:5,name:&#39;小白龙&#39;},
            ]
        }
    })
</script>
로그인 후 복사

출력 결과 살펴보기

Vue의 슬롯에 대해 알아보기

관련 권장 사항:

2020 프론트엔드 vue 인터뷰 질문 요약(답변 포함)

vue 튜토리얼 권장 사항 : 2020년 최신 vue.js 비디오 튜토리얼 5개

더 많은 프로그래밍 관련 지식을 보려면 프로그래밍 소개를 방문하세요! !

위 내용은 Vue의 슬롯에 대해 알아보기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:cnblogs.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿