Vue中slot插槽作用与原理是什么

1、作用

  • 父组件向子组件传递内容

  • 扩展、复用、定制组件

2、插槽内心

2.1、默认插槽

把父组件中的数组,显示在子组件中,子组件通过一个slot插槽标签显示父组件中的数据。

子组件

<template>  <div class="slotChild">    <h5>{{msg}}</h5>    <slot>这是子组件插槽默认的值</slot>  </div></template><script>export default {  name: "slotChild",  data() {    return {      msg: "vue中的插槽---子组件"    }  }}</script>

父组件

<template>  <div class="slotStudy">    <h2>{{ msg }}</h2>    <SlotChild>      <p>这是父组件传入的值,将会替换子组件中slot中编写的默认值</p>    </SlotChild>  </div></template><script>import SlotChild from "@/components/slot/SlotChild";export default {  name: "slotStudy",  components: {SlotChild},  data() {    return {      msg: "vue中的插槽---父组件"    }  }}</script>

Vue中slot插槽作用与原理是什么

    <SlotChild></SlotChild>

Vue中slot插槽作用与原理是什么

2.2、具名插槽(命名插槽)

父组件中通过slot属性,给插槽命名,在子组件中通过slot标签,根据定义好的名字填充到对应的位置。这样就可以指定多个可区分的slot,在使用组件时灵活的进行插值。

子组件:

<template>  <div class="slotChild">    <h5>{{msg}}</h5>    <h2><slot name="h_1"></slot></h2>    <h3><slot name="h_2"></slot></h3>    <h4><slot name="h_3"></slot></h4>  </div></template><script>export default {  name: "slotChild",  data() {    return {      msg: "vue中的插槽---子组件"    }  }}</script>

父组件:

<template>  <div class="slotStudy">    <h2>{{ msg }}</h2>    <SlotChild>      <template v-slot:h_1>h2111111111的内容</template>      <!--      #简写-->      <template #h_2>h3222222的内容</template>      <template v-slot:h_3>h43333的内容</template>    </SlotChild>  </div></template><script>import SlotChild from "@/components/slot/SlotChild";export default {  name: "slotStudy",  components: {SlotChild},  data() {    return {      msg: "vue中的插槽---父组件"    }  }}</script>

Vue中slot插槽作用与原理是什么

2.3、作用域插槽

用得不多。

将子组件中data的数据传出,在父组件中使用。子组件渲染作用域插槽时,可以将子组件内部的数据传递给父组件,让父组件根据子组件的传递过来的数据决定如何渲染该插槽。在标签中通过v-slot=”要传过来的数据”来接收数据。

实现原理

实现原理:当子组件vm实例化时,获取到父组件传入的slot标签的内容,存放在vm. s l o t 中,默认插槽为 v m . slot中,默认插槽为vm. slot中,默认插槽为vm.slot.default,具名插槽为vm. s l o t . x x x , x x x 为插槽名,当组件执行渲染函数时候,遇到 s l o t 标签,使用 slot.xxx,xxx 为插槽名,当组件执行渲染函数时候,遇到slot标签,使用 slot.xxx,xxx为插槽名,当组件执行渲染函数时候,遇到slot标签,使用slot中的内容进行替换,此时可以为插槽传递数据,若存在数据,则可称该插槽为作用域插槽。

子组件:

<template>  <div class="slotChild">    <h5>{{ msg }}</h5>    <h2>      <slot :str="strDate" name="n_str">{{ strDate.name }}</slot>    </h2>    <h3>      <slot :str="strDate" name="j_str">{{ strDate.job }}</slot>    </h3>  </div></template><script>export default {  name: "slotChild",  data() {    return {      msg: "vue中的插槽---子组件",      strDate: {        name: "学习前端的小方同学",        job: "找工作中",        age:"我每年都是18"      }    }  }}</script>

父组件:

<template>  <div class="slotStudy">    <h2>{{ msg }}</h2>    <SlotChild>      <template #n_str="strProps">        {{ strProps.str.job }}      </template>      <template v-slot:j_str="strProps">        {{ strProps.str.age }}      </template>    </SlotChild>  </div></template><script>import SlotChild from "@/components/slot/SlotChild";export default {  name: "slotStudy",  components: {SlotChild},  data() {    return {      msg: "vue中的插槽---父组件"    }  }}</script>

Vue中slot插槽作用与原理是什么

“Vue中slot插槽作用与原理是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

文章标题:Vue中slot插槽作用与原理是什么,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/28976

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
亿速云的头像亿速云认证作者
上一篇 2022年9月22日 下午10:17
下一篇 2022年9月22日 下午10:18

相关推荐

  • windows nvidia驱动如何更新

    nvidia驱动更新方法: 1、首先我们下载一个nvidia GeForce experience软件。 2、下载安装完成后,点击右下角的nvidia图标,打开nvidia GeForce experience。 3、打开后,进入上方的“驱动程序”选项。 4、然后点击“检查更新文件”可以扫描到最新的…

    2022年8月29日
    53000
  • Javascript怎样替换数组中的特定值

    替换数组中的特定值 splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目。该方法会改变原始数组。特别需要注意插入值的位置! // arrayObject.splice(index,howmany,item1,…..,itemX)var plants = [‘Saturn’, ‘…

    2022年8月31日
    66100
  • windows deepin没有无线网络怎么解决

    解决方法: 方法一: 1、可以尝试先切换回windows系统,然后下载驱动人生。 2、然后在windows系统下更新自己的无线网卡驱动,更新后再切换回deepin系统看看能否显示。 方法二: 1、如果windows修复无效,那么回到deepin,打开“深度终端” 2、在其中输入“lspci | gr…

    2022年9月21日
    91800
  • potplayer播放视频没有声音如何解决

    potplayer播放视频没有声音的详细教程解决方法: 1、打开potplayer安装程序,然后选择【简体中文】,点击【OK】。 2、然后就是点击【下一步】,点击【我接受】。 3、在组件界面中,在【关联】下面,勾选上【关联所有格式】,其它的就随便了,然后点击【下一步】。 4、然后选择好位置以后,点击…

    2022年9月1日
    2.2K00
  • mysql substring()函数如何用

    在mysql中,substring()函数用于截取字符串,可以从字符串从特定位置开始返回一个给定长度的子字符串,语法为“SUBSTRING(字符串,n)”,参数“n”的值需要是一个整数,用于指定子串的起始字符,可以为负值。若参数“n”为负值,则子串的位置起始于字符串结尾的第n个字符,即倒数第n个字符…

    2022年9月26日
    1.5K00
  • php如何将数据强转为字符串类型

    两种转换方法:1、在数据之前加上用括号括起来的目标类型“(string)”,语法“(string)指定数据”。2、使用强制类型转换函数strval()或settype(),语法“strval(指定数据)”或“settype(指定数据2,”string”)”。 本教程操作环境:…

    2022年9月26日
    1.6K00
  • java BigDecimal类应用实例代码分析

    一.介绍 float和double类型的主要设计目标是为了科学计算和工程计算。他们执行二进制浮点运算,这是为了在广域数值范围上提供较为精确的快速近似计算而精心设计的。然而,它们没有提供完全精确的结果,所以不应该被用于要求精确结果的场合。但是,商业计算往往要求结果精确,这时候BigDecimal就派上…

    2022年8月31日
    63900
  • windows默认网关不可用怎么解决

    默认网关不可用解决方法: 1、首先按下“Win+R”打开运行,输入“CMD”并打开。 2、打开管理员界面后,输入命令“netsh winsock reset”并按下回车。 3、然后再输入“netsh int ip reset reset.log”,然后再点击回车运行该命令,然后重启电脑运行。 4、然…

    2022年9月22日
    2.3K00
  • windows会声会影如何导出视频高清

    会声会影导出视频高清的方法 1、首先我们要保证我们的源视频是高清的,否则无论如何操作都无法导出高清的视频。 2、接着我们在导入视频前要设置高清的项目环境,这样我们就能在高清的环境中编辑视频了。 3、点击左上角“设置”,选择“项目属性”。 4、根据我们需要的参数设置相应的项目格式。 5、当我们编辑完成…

    2022年9月15日
    55800
  • windows浩辰cad看图王图片怎么放大

    浩辰cad看图王图片放大步骤: 一、按钮调整。 1、打开对应的文件。 2、找到如图位置的放大镜按钮。 3、选择需要使用的放大/缩小。 二、鼠标调整。 按住你的键盘ctrl,同时滑动鼠标的滚轮,向上是放大,向下是缩小。 到此,关于“windows浩辰cad看图王图片怎么放大”的学习就结束了,希望能够解…

    2022年9月21日
    74100
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部