zoukankan      html  css  js  c++  java
  • Vue学习笔记Vue.js2.X 学习(三)===>组件化高级

    (四) 组件化高级

    1.插槽(slot)的基本使用

    A:基本使用: <slot></slot>

    B:默认置:<slot><h1>中间可以放默认值</h1></slot>

    C:如果有多个值,同时放入到组件进行替换时,一起作为替换元素

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    <!--父组件模版-->
    <div id="app">
        <zzj1><button>按钮</button></zzj1> <!--组件1加个按钮-->
        <zzj1>长安镖局</zzj1> <!--组件2加个长安镖局-->
        <zzj1><h1>预留插槽后中间可以随便放</h1></zzj1> <!--组件3加个h1标签-->
        <zzj1></zzj1> <!--组件4显示默认值-->
    
    </div>
    <!--子组件模版 -->
    <template id="zzjmb">
        <div>
            <h2>{{title}}</h2>
            <!--预留插槽,以便扩展组件,组件中抽取共性,把不同的预留在插槽-->
            <!--<slot></slot>-->
            <slot><h1>中间可以放默认值</h1></slot>
        </div>
    </template>
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <script>
        // root根组件(父组件)
        const app = new Vue({
            el: '#app',
            // 创建注册子组件
            components: {
                zzj1: {
                    template: '#zzjmb',
                    data() {
                        return {
                            title: '子组件data中的数据'
                        }
                    },
                }
            }
        })
    </script>
    </body>
    </html>
    
    插槽(slot)的基本使用
    插槽(slot)的基本使用

     

     2.具名插槽(slot)的使用

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    <!--父组件模版-->
    <div id="app">
        <zzj1><button>按钮</button></zzj1> <!--替换默认插槽-->
        <zzj1><button slot="left">替换左边</button></zzj1> <!--替换左边插槽-->
    </div>
    <!--子组件模版 -->
    <template id="zzjmb">
        <div>
            <h2>{{title}}</h2>
            <!--具名插槽-->
            <slot name="left"><span>左边</span></slot>
            <slot name="center"><span >中间</span></slot>
            <slot name="right"><span>右边</span></slot>
            <slot ><span>默认</span></slot>
        </div>
    </template>
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <script>
        // root根组件(父组件)
        const app = new Vue({
            el: '#app',
            // 创建注册子组件
            components: {
                zzj1: {
                    template: '#zzjmb',
                    data() {
                        return {
                            title: '子组件data中的数据-具名插槽'
                        }
                    },
                }
            }
        })
    </script>
    </body>
    </html>
    
    具名插槽(slot)的使用
    具名插槽(slot)的使用

     

    3.变量编译的作用域

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    <!--父组件模版-->
    <div id="app">
    <!--执行isshow会在当前模版中查找-->
        <zzj1 v-show="isshow"></zzj1>
    </div>
    <!--子组件模版 -->
    <template id="zzjmb">
        <div>
            <h2>{{title}}</h2>
        </div>
    </template>
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <script>
        // root根组件(父组件)
        const app = new Vue({
            el: '#app',
            data: {
                title:'我是父组件',
                isshow:true
            },
            // 创建注册子组件
            components: {
                zzj1: {
                    template: '#zzjmb',
                    data() {
                        return {
                            title: '子组件data中的数据-编译的作用域',
                            isshow: false,
                        }
                    },
                }
            }
        })
    </script>
    </body>
    </html>
    
    变量编译的作用域
    变量编译的作用域

    4.作用域插槽 (父组件替换插槽的标签,但是内容由子组件来提供)

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body><!--作用域插槽==>父组件替换插槽的标签,但是内容由子组件来提供-->
    <!--父组件模版-->
    <div id="app">
        <zzj1><span slot="left" >子组件中展示的格式:</span></zzj1> <!--替换左边具名插槽-->
        <zzj1>
            <!--使用插槽的数据外面可以是template标签,也可以是其它标签-->
            <span slot="left">父组件中展示的格式后面有"-":</span>
            <template slot-scope="fyuyan1">  <!--用slot-scope接收子组件传的数据,后面变量名自定义-->
                <span v-for="i in fyuyan1.data">{{i}} - </span><!--用变量名.data来使用数据-->
            </template>
        </zzj1>
        <zzj1>
            <span slot="left">父组件中展示的格式去掉后面的"-":</span>
            <div slot-scope="fyuyan2">
                <span>{{fyuyan2.data.join('-')}}</span><!--用join函数来展示-->
            </div>
        </zzj1>
    </div>
    <!--子组件模版 -->
    <template id="zzjmb">
        <div>
            <ul>
                <slot name="left"><span>左边</span></slot>
                <slot :data="yuyan"><li v-for="i in yuyan">{{i}}</li></slot><!--自定义绑定名data,来绑定发射子组件的数据-->
            </ul>
        </div>
    </template>
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <script>
        const app = new Vue({
            el: '#app',
            data: {},
            components: {
                zzj1: {
                    template: '#zzjmb',
                    data() {
                        return {
                            yuyan:['python','go','vue'],
                            title: '子组件data中的数据-编译的作用域',
                        }
                    },
                }
            }
        })
    </script>
    </body>
    </html>
    作用域插槽

    Vue学习笔记-Vue.js-2.X 学习(四)

  • 相关阅读:
    uva11025 The broken pedometer
    uva131 The Psychic Poker Player
    子集生成算法
    uva10167 Birthday Cake
    poj1129 Channel Allocation
    poj2676 Sudoku
    Emacs杂谈(一)Emacs环境 c++ 快捷键
    poj1416 Shredding Company
    英文报刊推荐
    搜索练习(二)工作效益
  • 原文地址:https://www.cnblogs.com/djtang/p/14078826.html
Copyright © 2011-2022 走看看