vue插槽初步了解

首先我们想先创建一个子组件

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Vue中的插槽(slot)</title>
    <script src='./vue.js'></script>
</head>

<body>

    <div id="root">
        <child></child>
    </div>

    <script>
        Vue.component('child', {
            template: '<div><p>hello</p></div>'
        })


        var vm = new Vue({
            el: '#root'
        })
    </script>

</body>

</html>

然后 我如何转意p标签呢

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Vue中的插槽(slot)</title>
    <script src='./vue.js'></script>
</head>

<body>

    <div id="root">
        <!-- 向子组件进行传值 -->
        <child content='<p>Dell</p>'></child>
    </div>

    <script>
        Vue.component('child', {
            props: ['content'],
            // 接受过content后我们可以插入插值表达式里了
            template: `<div>
                        <p>hello</p>
                        <div v-html="this.content"></div>
                        </div>`
        })


        var vm = new Vue({
            el: '#root'
        })
    </script>

</body>

</html>

运行效果图
在这里插入图片描述
我们发现转义成功
但是我们有更好的解决方案

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Vue中的插槽(slot)</title>
    <script src='./vue.js'></script>
</head>

<body>

    <div id="root">

        <child>
            <p>Dell</p>
        </child>
    </div>

    <script>
        Vue.component('child', {

            //    这里显示的就是父组件向子组件插入的标签
            template: `<div>
                       <slot></slot>
                        </div>`
        })


        var vm = new Vue({
            el: '#root'
        })
    </script>

</body>

</html>

在这里插入图片描述
通过插槽 我们可以更好的调用dom元素

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Vue中的插槽(slot)</title>
    <script src='./vue.js'></script>
</head>

<body>

    <div id="root">

        <h1>
            <p>Dell</p>
        </h1>
    </div>

    <script>
        Vue.component('child', {

            //    这里显示的就是父组件向子组件插入的标签
            template: `<div>
                       <p>Hello</p>
                       <slot></slot>
                        </div>`
        })


        var vm = new Vue({
            el: '#root'
        })
    </script>

</body>

</html>

在这里插入图片描述
这里还有个有趣的现象 下面的默认内容不显示

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Vue中的插槽(slot)</title>
    <script src='./vue.js'></script>
</head>

<body>

    <div id="root">

        <h1>
            <p>Dell</p>
        </h1>
    </div>

    <script>
        Vue.component('child', {

            //    这里显示的就是父组件向子组件插入的标签
            template: `<div>
                       <p>Hello</p>
                       <slot>默认内容</slot>
                        </div>`
        })


        var vm = new Vue({
            el: '#root'
        })
    </script>

</body>

</html>

在这里插入图片描述
但是如果将插槽的内容取消

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Vue中的插槽(slot)</title>
    <script src='./vue.js'></script>
</head>

<body>

    <div id="root">

        <child></child>
    </div>

    <script>
        Vue.component('child', {

            //    这里显示的就是父组件向子组件插入的标签
            template: `<div>
                       <p>Hello</p>
                       <slot>默认内容</slot>
                        </div>`
        })


        var vm = new Vue({
            el: '#root'
        })
    </script>

</body>

</html>

在这里插入图片描述
此时我们看另外一个例子

首先不使用插槽:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Vue中的插槽(slot)</title>
    <script src='./vue.js'></script>
</head>

<body>

    <div id="root">
        <content>

        </content>


    </div>

    <script>
        Vue.component('child', {


            template: `<div>
                      <div class= 'content'>content</div>
                        </div>`
        })


        var vm = new Vue({
            el: '#root'
        })
    </script>

</body>

</html>

运行效果

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Vue中的插槽(slot)</title>
    <script src='./vue.js'></script>
</head>

<body>

    <div id="root">
        <content>
        </content>


    </div>

    <script>
        Vue.component('content', {


            template: `<div>
                      <div class= 'content'>content</div>
                        </div>`
        })


        var vm = new Vue({
            el: '#root'
        })
    </script>

</body>

</html>

在这里插入图片描述
因为content是关键字 所以我们改一个名字就可以了

具体代码如下

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Vue中的插槽(slot)</title>
    <script src='./vue.js'></script>
</head>

<body>

    <div id="root">
        <body-content>
        </body-content>


    </div>

    <script>
        Vue.component('body-content', {


            template: `<div>
                      <div class= 'content'>content</div>
                        </div>`
        })


        var vm = new Vue({
            el: '#root'
        })
    </script>

</body>

</html>

在这里插入图片描述
接下来 我们再写一个例子 看看效果

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Vue中的插槽(slot)</title>
    <script src='./vue.js'></script>
</head>

<body>

    <div id="root">
        <body-content>
            <div class='header'>header</div>
            <div class='footer'>footer</div>

        </body-content>


    </div>

    <script>
        Vue.component('body-content', {


            template: `<div>
                        <slot></slot>
                      <div class= 'content'>content</div>
                      <slot></slot>
                        </div>`
        })


        var vm = new Vue({
            el: '#root'
        })
    </script>

</body>

</html>

在这里插入图片描述
之所以显示成这样是因为
在这里插入图片描述
这两个插槽 都起作用了 但是有没有好的解决方案

我们可以给插槽起名字

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Vue中的插槽(slot)</title>
    <script src='./vue.js'></script>
</head>

<body>

    <div id="root">
        <body-content>
            <div class='header' slot='header'>header</div>
            <div class='footer' slot='footer'>footer</div>

        </body-content>


    </div>

    <script>
        Vue.component('body-content', {


            template: `<div>
                        <slot name='header'></slot>
                      <div class= 'content'>content</div>
                      <slot name='footer'></slot>
                        </div>`
        })


        var vm = new Vue({
            el: '#root'
        })
    </script>

</body>

</html>

在这里插入图片描述

Vue中的插槽(slot)
<div id="root">
    <body-content>

        <div class='footer' slot='footer'>footer</div>

    </body-content>


</div>

<script>
    Vue.component('body-content', {


        template: `<div>
                    <slot name='header'>default header</slot>
                  <div class= 'content'>content</div>
                  <slot name='footer'></slot>
                    </div>`
    })


    var vm = new Vue({
        el: '#root'
    })
</script>

在这里插入图片描述

Vue中的插槽(slot)
<div id="root">
    <body-content>

        <div class='footer' slot='footer'>footer</div>

    </body-content>


</div>

<script>
    Vue.component('body-content', {


        template: `<div>
                    <slot name='header'>
                    <h1>default header</h1>
                    </slot>
                  <div class= 'content'>content</div>
                  <slot name='footer'></slot>
                    </div>`
    })


    var vm = new Vue({
        el: '#root'
    })
</script>

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【课程特点】1、231节大容量课程:包含了SwiftUI的大部分知识点,详细讲解SwiftUI的方方面面;2、15个超级精彩的实例:包含美食、理财、健身、教育、电子商务等各行业的App实例;3、创新的教学模式:手把手教您SwiftUI用户界面开发技术,一看就懂,一学就会;4、贴心的操作提示:让您的眼睛始终处于操作的焦点位置,不用再满屏找光标;5、语言简洁精练:瞄准问题的核心所在,减少对思维的干扰,并节省您宝贵的时间;6、视频短小精悍:即方便于您的学习和记忆,也方便日后对功能的检索;7、齐全的学习资料:提供所有课程的源码,在Xcode 11 + iOS 13环境下测试通过; 更好的应用,更少的代码!SwiftUI是苹果主推的下一代用户界面搭建技术,具有声明式语法、实时生成界面预览等特性,可以为苹果手机、苹果平板、苹果电脑、苹果电视、苹果手表五个平台搭建统一的用户界面。SwiftUI是一种创新、简单的iOS开发中的界面布局方案,可以通过Swift语言的强大功能,在所有的Apple平台上快速构建用户界面。 仅使用一组工具和API为任何Apple设备构建用户界面。SwiftUI具有易于阅读和自然编写的声明式Swift语法,可与新的Xcode设计工具无缝协作,使您的代码和设计**同步。自动支持动态类型、暗黑模式、本地化和可访问性,意味着您的**行SwiftUI代码已经是您编写过的非常强大的UI代码了。 

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值