阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

简单介绍关于vue 的slot分发内容 (多个分发)

283次阅读
没有评论

共计 2825 个字符,预计需要花费 8 分钟才能阅读完成。

导读 这篇文章主要介绍了关于 vue 的 slot 分发内容 (多个分发),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
slot 分发内容 (多个分发)

组件模板 - 元素可以用一个特殊的属性 name 来配置如何分发内容。多个 slot 可以有不同的名字。具名 slot 将匹配内容片段中有对应 slot 特性的元素

< style media="screen">
    .panel{
      margin:10px;width:150px;
      border:1px solid #ccc
    }
    .panel-header,.panel-bottom{
      height: 20px;
      background-color:antiquewhite;
    }
    .panel-body{min-height: 50px;}
  < /style>
< div class="app">
    < !-- 多个 slot 分发内容 v-for 遍历 -->
     < panel2 v-for="item in list">
       < h2 slot="title">{{item.title}}
       < p slot="desc">{{item.desc}}
       < span slot="tims">{{item.tims}}
     < /panel2>
  < /div>
< !-- 组件模板 -->
< script type="text/x-Template" id="panelTpl">
   < div class="panel">
       < div class="panel-header">
       < div class="panel-body">
         < slot name="desc">
       < /div>
       < div class="panel-bottom">
   < /div>
< /script>
< script type="text/javascript">
var panelTpl={template:'#panelTpl'}
var vm=new Vue({
  el:'.app',
  components:{// 注册组件
    "panel2":panelTpl
  },
  data:{
    list:[{title:'新闻一标题',desc:'一的描述',tims:'2018-07-19'},
      {title:'新闻二标题',desc:'二的描述',tims:'2018-07-18'},
      {title:'新闻三标题',desc:'三的描述',tims:'2018-07-17'}
    ]
  }
});
< /script>

简单介绍关于 vue 的 slot 分发内容 (多个分发)

slot 的多种用法
基本用法
// 组件
< template>
    < div class="com">
        < slot name="header">
        < slot> 如果没有插槽或者不具名就是显示当前
        < slot name="floot">
    < /div>
< /template>
< script>
    export default { }
< /script>
  
// 使用
< template>
    < div id="app">
        < com>
            < div class="header" slot="header">
                我将会插入到名为 header 的插槽当中
            < /div>
            < div class="floot" slot="floot">
                我将会插入到名为 floot 的插槽当中
            < /div>
        < /com>
    < /div>
< /template>
< script>
import com from '@/components/com.vue';
export default {
    name:"App",
    components:{com}
}
< /script>
插槽中使用 data
// 组件
< template>
    < div class="com">
        < slot name="header" :slotData="comData">//slotData 表示插槽 key 值
        < slot> 如果没有插槽或者不具名就是显示当前
        < slot name="floot" :slotData="comData">
    < /div>
< /template>
  
< script>
    export default {data() {
            return {
                comData:{
                    header:"我将会插入到名为 header 的插槽当中",
                    floot:"我将会插入到名为 floot 的插槽当中"
                }
            }
        },
    }
< /script>
  
// 使用
< template>
    < div id="app">
        < com>
            < template v-slot:header="{slotData}">
                // 必须使用 template 包裹,v-slot 后面跟着的是插槽名,slotData 插槽里表示的 key 值
                < div class="header">
                    {{slotData.header}}
                < /div>
            < /template>
            < template v-slot:floot="{slotData}">
                < div class="floot">
                    {{slotData.floot}}
                < /div>
            < /template>
        < /com>
    < /div>
< /template>
< script>
import com from '@/components/com.vue';
export default {
    name:"App",
    components:{com}
}
< /script>
动态插槽
// 组件
< template>
    < div class="com">
        < slot name="header" :slotData="comData">
        < slot name="body" :slotData="comData">
        < slot name="floot">
    < /div>
< /template>
  
< script>
    export default {data() {
            return {
                comData:{
                    header:"我将会插入到名为 header 的插槽当中",
                    body:"我将会插入到名为 body 的插槽当中"
                }
            }
        },
    }
< /script>
  
// 使用
< template>
    < div id="app">
        < com>
            < template v-slot:[slotName]="{slotData}">
                < div class="slot">
                    {{slotData[slotName]}}
                < /div>
            < /template>
            < div class="floot" slot="floot">
                < button @click="changeSlotName"> 改变动态插槽
            < /div>
        < /com>
    < /div>
< /template>
< script>
import com from '@/components/com.vue';
export default {
    name:"App",
    components:{com},
    data(){
        return{slotName:"header"}
    },
    methods: {changeSlotName(){this.slotName = this.slotName === "header" ? "body" : "header";}
    }
}
< /script>

以上为个人经验,希望能给大家一个参考。

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-07-25发表,共计2825字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19350
评论数
4
阅读量
7901116
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见 zabbix!轻量级自建服务器监控神器在 Linux 的完整部署指南 在日常运维中,服务器监控是绕不开的...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
安装Black群晖DSM7.2系统安装教程(在Vmware虚拟机中、实体机均可)!

安装Black群晖DSM7.2系统安装教程(在Vmware虚拟机中、实体机均可)!

安装 Black 群晖 DSM7.2 系统安装教程(在 Vmware 虚拟机中、实体机均可)! 前言 大家好,...
星哥带你玩飞牛NAS-13:自动追番、订阅下载 + 刮削,动漫党彻底解放双手!

星哥带你玩飞牛NAS-13:自动追番、订阅下载 + 刮削,动漫党彻底解放双手!

星哥带你玩飞牛 NAS-13:自动追番、订阅下载 + 刮削,动漫党彻底解放双手! 作为动漫爱好者,你是否还在为...
三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Android 的最优解?

三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Android 的最优解?

  三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Andr...
星哥带你玩飞牛 NAS-10:备份微信聊天记录、数据到你的NAS中!

星哥带你玩飞牛 NAS-10:备份微信聊天记录、数据到你的NAS中!

星哥带你玩飞牛 NAS-10:备份微信聊天记录、数据到你的 NAS 中! 大家对「数据安全感」的需求越来越高 ...
仅2MB大小!开源硬件监控工具:Win11 无缝适配,CPU、GPU、网速全维度掌控

仅2MB大小!开源硬件监控工具:Win11 无缝适配,CPU、GPU、网速全维度掌控

还在忍受动辄数百兆的“全家桶”监控软件?后台偷占资源、界面杂乱冗余,想查个 CPU 温度都要层层点选? 今天给...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face 免费服务器 +Docker 快速部署 HertzBeat 监控平台 ...
浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍

浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍

浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍 前言 在 AI 自动化快速发展的当下,浏览器早已不再只是...
星哥带你玩飞牛NAS-8:有了NAS你可以干什么?软件汇总篇

星哥带你玩飞牛NAS-8:有了NAS你可以干什么?软件汇总篇

星哥带你玩飞牛 NAS-8:有了 NAS 你可以干什么?软件汇总篇 前言 哈喽各位玩友!我是是星哥,不少朋友私...
三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Android 的最优解?

三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Android 的最优解?

  三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Andr...
把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地 大家好,我是星哥,今天教大家在飞牛 NA...