广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >关于vue的slot分发内容(多个分发)
  • 114
分享到

关于vue的slot分发内容(多个分发)

2024-04-02 19:04:59 114人浏览 独家记忆
摘要

目录slot分发内容 (多个分发)slot的多种用法基本用法插槽中使用data动态插槽slot分发内容 (多个分发)  组件模板-元素可以用一个特殊的属性 name 来配置

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}}</h2>
       <p slot="desc">{{item.desc}}</p>
       <span slot="tims">{{item.tims}}</span>
     </panel2>
  </div>
<!--组件模板-->
<script type="text/x-Template" id="panelTpl">
   <div class="panel">
       <div class="panel-header"><slot name="title"></slot></div>
       <div class="panel-body">
         <slot name="desc"></slot>
       </div>
       <div class="panel-bottom"><slot name="tims"></slot></div>
   </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>

slot的多种用法

基本用法

//组件
<template>
    <div class="com">
        <slot name="header"></slot>
        <slot>如果没有插槽或者不具名就是显示当前</slot>
        <slot name="floot"></slot>
    </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"></slot>//slotData表示插槽key值
        <slot>如果没有插槽或者不具名就是显示当前</slot>
        <slot name="floot" :slotData="comData"></slot>
    </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>
        <slot name="body" :slotData="comData"></slot>
        <slot name="floot"></slot>
    </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">改变动态插槽</button>
			</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>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。 

--结束END--

本文标题: 关于vue的slot分发内容(多个分发)

本文链接: https://www.lsjlt.com/news/144351.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 关于vue的slot分发内容(多个分发)
    目录slot分发内容 (多个分发)slot的多种用法基本用法插槽中使用data动态插槽slot分发内容 (多个分发)  组件模板-元素可以用一个特殊的属性 name 来配置...
    99+
    2022-11-13
  • vue中slot内容分发的示例分析
    小编给大家分享一下vue中slot内容分发的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!vue的内容分发非常适合“固定...
    99+
    2022-10-19
  • vue中slot分发内容的示例分析
    这篇文章主要为大家展示了“vue中slot分发内容的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue中slot分发内容的示例分析”这篇文章吧。slot分发内容 (多个分发) ...
    99+
    2023-06-29
  • 如何使用vue slot分发内容
    本文小编为大家详细介绍“如何使用vue slot分发内容”,内容详细,步骤清晰,细节处理妥当,希望这篇“如何使用vue slot分发内容”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、什么是slot在使用组件时...
    99+
    2023-07-04
  • Vue中内容分发<slot>​的示例分析
    这篇文章主要介绍Vue中内容分发<slot>的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!首先 Vue 实现了一套内容分发的 API,这套 API 是基于当前的...
    99+
    2022-10-19
  • vue中怎么使用slot分发内容
    这篇文章将为大家详细讲解有关vue中怎么使用slot分发内容,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、什么是slot在使用组件时,我们常常要像这样组...
    99+
    2022-10-19
  • Vue中怎么使用slot实现内容分发
    这篇文章给大家介绍Vue中怎么使用slot实现内容分发,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。编译作用域在深入内容分发 API 之前,先明确内容在哪个作用域里编译。假定模板为&l...
    99+
    2022-10-19
  • 关于Java的HashMap多线程并发问题分析
    目录并发问题的症状多线程put后可能导致get死循环多线程put的时候可能导致元素丢失put非null元素后get出来的却是nullHashMap数据结构HashMap的rehash...
    99+
    2023-05-19
    Java HashMap HashMap多线程并发
  • Vue之自定义事件内容分发详解
    1、小伙伴们这个理解起来有点复杂,希望仔细看里面的原理,自己去敲一遍: <!DOCTYPE html> <html lang="en"> <head...
    99+
    2022-11-12
  • 关于TypeScript开发的6六个实用小技巧分享
    目录1. 开发之前确定实体类型 2. 请求接口时只需要定义自己需要用到的字段 3. 使用枚举类型 4. DOM元素的类型要正常给 5.对象的类型要怎么给 6.结构赋值时类型怎么给 总...
    99+
    2022-11-12
  • Vue开发的36个技巧分享
    本篇内容介绍了“Vue开发的36个技巧分享”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言Vue 3.x...
    99+
    2022-10-19
  • 关于Keras 2.3.0 发布中的TensorFlow 2.0分析
    本篇文章为大家展示了关于Keras 2.3.0 发布中的TensorFlow 2.0分析,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Keras主要关注tf.keras,同时继续支持Theano/C...
    99+
    2023-06-05
  • 云服务器属于哪个分类管理的内容
    云服务器通常是指公共云服务或私有云服务,它们是由许多不同的软件和硬件组件组成的,这些组件共享同一个基础设施平台,包括存储、处理、网络等服务。这些服务可以通过互联网连接到任何地方,从而使用户可以在家中、工作场所或旅途中访问各种资源。 例如,...
    99+
    2023-10-26
    服务器 内容
  • 7个很棒的Vue开发技巧分享
    目录1.路由参数解耦2.功能组件3.样式范围4.watch的高级使用5.watch监听多个变量6.事件参数$event7.程序化事件监听器1.路由参数解耦 通常在组件中使用路由参数,...
    99+
    2023-02-08
    Vue开发技巧 Vue技巧
  • Python中关于前后端分离开发入门的示例分析
    本篇文章为大家展示了Python中关于前后端分离开发入门的示例分析,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。前后端分离开发入门在传统的Web应用开发中,大多数的程序员会将浏览器作为前后端的分界线...
    99+
    2023-06-02
  • 关于Android触摸事件分发的原理详析
    目录一:前言二:说在前面的知识三:整体流程1:activity2:window就是PhoneWindow3:view group4:view四:一些关键点五:从源码看触摸事件分发总结...
    99+
    2022-11-12
  • javascript关于前端开发语言的示例分析
    这篇文章将为大家详细讲解有关javascript关于前端开发语言的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1、javascript是前端开发语言,经常与html、css技术一起构成前端开发。...
    99+
    2023-06-20
  • 关于Java单个TCP(Socket)连接发送多个文件的问题
    目录使用一个TCP连接发送多个文件协议的作用定义数据的发送格式(协议)代码客户端服务器端测试结果总结使用一个TCP连接发送多个文件 为什么会有这篇博客? 最近在看一些相关方面的东西,...
    99+
    2023-05-15
    Java单个(Socket)TCP Java TCP发送多个文件
  • 云服务器属于哪个分类类别管理的内容
    云服务器通常被分为以下类别: 公共云:指由一个或多个云供应商提供的云平台,如亚马逊AWS和微软Azure等。 私有云:指企业或组织使用公共云平台,如谷歌云、亚马逊云、阿里云等。 专属云:指专为特定行业或组织的需求而量身定制的云平台,如医...
    99+
    2023-10-27
    类别 服务器 内容
  • 云服务器属于哪个分类管理的内容类别
    云服务器通常是指用于创建、托管、管理和维护云计算资源的服务器。云服务器可以是一家公司或者多个公司共同管理的资源,也可以是单独购买的一台服务器或者使用租用的云服务器软件来管理。根据管理方式的不同,云服务器可以分为公共云服务器、本地云服务器、托...
    99+
    2023-10-27
    类别 服务器 内容
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作