vuejs 슬롯 사용 방법: 1. 하위 구성 요소에 일부 DOM을 넣습니다. 2. 슬롯을 통해 DOM을 표시하거나 숨깁니다(예: "new Vue({el: "#app",data: {},comComponents)). :{ 어린이들:{...}}})".
이 기사의 운영 환경: Windows 7 시스템, vue 버전 2.9.6, DELL G3 컴퓨터.
vuejs의 슬롯 사용
개요:
상위 구성 요소가 하위 구성 요소에 일부 DOM을 넣어야 하는 경우 슬롯 배포는 이러한 DOM이 표시되는지 또는 숨겨지는지, 표시되는 위치를 담당합니다. 그리고 그것이 어떻게 표시되는지.
다음 상황에서 배포됩니다.
我是slot内容
표시 결과는 다음과 같습니다. 스팬 태그의 내용이 표시되지 않습니다.
싱글 슬롯:
我是slot内容
即父组件放在子组件里的内容,插到了子组件位置; 注意:即使有多个标签,会一起被插入,相当于在父组件放在子组件里的标签,替换了 这个标签。 例如:
我是slot内容 测试测试
我是测试的
D:具名slot:将放在子组件里的不同html标签放到不同位置,父组件在要发布的标签里添加slot=”name名”属性,子组件在对应分发的位置的slot标签里,添加name=”name名”属性,然后就会将对应的标签放在对应位置了。 例如:
12345 56789
E:分发内容的作用域: 被分发的内容的作用域,根据其所在模块决定,例如:点击按钮12345的区域时(而不是全部按钮),会触发父组件的test方法,然后打印“我是first点击打印的内容”。但是点击其他区域则没有影响。
12345 56789
F:当没有分发内容时的提示:假如父组件没有在子组件中放置有标签,或者是父组件在子组件中放置标签,但有slot属性,而子组件中没有slot属性的标签。那么子组件的slot标签,将不会起任何作用。除非,该slot标签内有内容,那么在无分发内容的时候,会显示该slot标签内的内容。 例如:
【12345】
如果改为:
【12345】
说明:a、name=”first”的slot标签被父组件对应的标签所替换(slot标签内部的内容被舍弃) b、name=”last”的slot标签,因为没有对应内容,则显示该slot标签内部的内容。 G、假如想控制子组件根标签的属性【1】首先,由于模板标签是属于父组件的,因此,将子组件的指令绑定在模板标签里,是不可以的(因为其归属于父组件) 【2】假如需要通过父组件控制子组件是否显示(例如v-show或v-if),那么这个指令显然是属于父组件的,可以将标签写在子组件的模板上。例如:
点击之后:
说明:通过父组件(点击按钮,切换v-if指令的值)控制子组件是否显示。 【3】假如需要通过子组件,控制子组件是否显示(比如隐藏)那么这个指令显然是属于子组件的(会将值放在子组件的data属性下)那么就必须放置在子组件的根标签中。 例如:
【12345】
"여기에 하위 구성 요소가 있습니다"를 클릭한 후:
"하위 구성 요소를 표시하려면 클릭하세요"를 클릭하세요.
지침:
하위 구성 요소를 클릭하면 하위 구성 요소가 사라집니다
상위 구성요소의 버튼을 클릭하고 하위 구성요소의 tohidden 속성을 변경하여 하위 구성요소를 다시 표시하도록 합니다.
하위 구성 요소의 명령은 하위 구성 요소의 템플릿에 바인딩됩니다(호출 가능).
추천 학습: "vue tutorial"
위 내용은 vuejs 슬롯을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!